@nlabs/lex 1.49.3 → 1.49.4
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/eslint.config.mjs
CHANGED
|
@@ -5,16 +5,6 @@ export default [
|
|
|
5
5
|
{
|
|
6
6
|
ignores: ['*.md'],
|
|
7
7
|
rules: {
|
|
8
|
-
'keyword-spacing': ['error', {
|
|
9
|
-
after: true,
|
|
10
|
-
before: true,
|
|
11
|
-
overrides: {
|
|
12
|
-
for: {after: false},
|
|
13
|
-
if: {after: false},
|
|
14
|
-
switch: {after: false},
|
|
15
|
-
while: {after: false}
|
|
16
|
-
}
|
|
17
|
-
}],
|
|
18
8
|
'space-before-blocks': ['error', {
|
|
19
9
|
classes: 'always',
|
|
20
10
|
functions: 'always',
|
|
@@ -71,8 +71,8 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
71
71
|
nodir: true,
|
|
72
72
|
nosort: true
|
|
73
73
|
};
|
|
74
|
-
const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);
|
|
75
|
-
const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);
|
|
74
|
+
const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test|*.integration).ts*`, globOptions);
|
|
75
|
+
const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test|*.integration).js`, globOptions);
|
|
76
76
|
const sourceFiles = [...tsFiles, ...jsFiles];
|
|
77
77
|
const esbuildConfig = LexConfig.config.esbuild || {};
|
|
78
78
|
const isProduction = process.env.NODE_ENV === "production";
|
|
@@ -238,4 +238,4 @@ export {
|
|
|
238
238
|
compile,
|
|
239
239
|
hasFileType
|
|
240
240
|
};
|
|
241
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/compile/compile.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 {execa} from 'execa';\nimport {existsSync, lstatSync, readdirSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {extname as pathExtname, join as pathJoin, resolve as pathResolve} from 'path';\n\nimport {LexConfig, getTypeScriptConfigPath} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, copyFiles, createSpinner, getFilesByExt, removeFiles} from '../../utils/app.js';\nimport {getDirName, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport const hasFileType = (startPath: string, ext: string[]): boolean => {\n  if(!existsSync(startPath)) {\n    return false;\n  }\n\n  const files: string[] = readdirSync(startPath);\n\n  return files.some((file: string) => {\n    const filename: string = pathJoin(startPath, file);\n    const fileExt: string = pathExtname(filename);\n    const stat = lstatSync(filename);\n\n    if(stat.isDirectory()) {\n      return hasFileType(filename, ext);\n    }\n\n    return ext.includes(fileExt);\n  });\n};\n\nexport const compile = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    outputPath,\n    quiet,\n    remove,\n    sourcePath,\n    watch\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} compiling...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, sourceFullPath, useTypescript} = LexConfig.config;\n  const outputDir: string = outputPath || outputFullPath;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';\n  const dirName = getDirName();\n  const dirPath: string = pathResolve(dirName, '../..');\n\n  checkLinkedModules();\n\n  if(remove) {\n    await removeFiles(outputDir);\n  }\n\n  if(useTypescript) {\n    LexConfig.checkCompileTypescriptConfig();\n\n    const typescriptPath: string = resolveBinaryPath('tsc', 'typescript');\n\n    if(!typescriptPath) {\n      log(`\\n${cliName} Error: TypeScript binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const typescriptOptions: string[] = config ?\n      ['-p', config] :\n      ['-p', getTypeScriptConfigPath('tsconfig.build.json')];\n\n    spinner.start('Static type checking with Typescript...');\n\n    try {\n      await execa(typescriptPath, typescriptOptions, {encoding: 'utf8'});\n\n      spinner.succeed('Successfully completed type checking!');\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Type checking failed.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const globOptions = {\n    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);\n  const jsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n  const esbuildConfig = LexConfig.config.esbuild || {};\n  const isProduction = process.env.NODE_ENV === 'production';\n  let shouldMinify: boolean;\n\n  if(typeof esbuildConfig.minify === 'boolean') {\n    shouldMinify = esbuildConfig.minify;\n  } else {\n    shouldMinify = isProduction;\n  }\n\n  const esbuildPath: string = resolveBinaryPath('esbuild', 'esbuild');\n\n  if(!esbuildPath) {\n    log(`\\n${cliName} Error: esbuild binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your installation.', 'info', quiet);\n    return 1;\n  }\n\n  const esbuildOptions: string[] = [\n    ...sourceFiles,\n    '--color=true',\n    `--format=${esbuildConfig.format || 'esm'}`,\n    `--outdir=${outputDir}`,\n    `--platform=${esbuildConfig.platform || 'node'}`,\n    `--sourcemap=${esbuildConfig.sourcemap || 'inline'}`,\n    `--target=${esbuildConfig.target || 'node20'}`\n  ];\n\n  if(shouldMinify) {\n    esbuildOptions.push('--minify');\n  }\n\n  if(esbuildConfig.treeShaking !== false) {\n    esbuildOptions.push('--tree-shaking=true');\n  }\n\n  if(esbuildConfig.drop && esbuildConfig.drop.length > 0) {\n    esbuildConfig.drop.forEach((item) => {\n      esbuildOptions.push(`--drop:${item}`);\n    });\n  }\n\n  if(esbuildConfig.pure && esbuildConfig.pure.length > 0) {\n    esbuildConfig.pure.forEach((item) => {\n      esbuildOptions.push(`--pure:${item}`);\n    });\n  }\n\n  if(esbuildConfig.legalComments) {\n    esbuildOptions.push(`--legal-comments=${esbuildConfig.legalComments}`);\n  }\n\n  if(esbuildConfig.banner) {\n    Object.entries(esbuildConfig.banner).forEach(([type, content]) => {\n      esbuildOptions.push(`--banner:${type}=${content}`);\n    });\n  }\n\n  if(esbuildConfig.footer) {\n    Object.entries(esbuildConfig.footer).forEach(([type, content]) => {\n      esbuildOptions.push(`--footer:${type}=${content}`);\n    });\n  }\n\n  if(esbuildConfig.define) {\n    Object.entries(esbuildConfig.define).forEach(([key, value]) => {\n      esbuildOptions.push(`--define:${key}=${value}`);\n    });\n  }\n\n  if(watch) {\n    esbuildOptions.push('--watch');\n  }\n\n  const cssFiles: string[] = getFilesByExt('.css', LexConfig.config);\n\n  if(cssFiles.length) {\n    const postcssPath: string = resolveBinaryPath('postcss', 'postcss-cli');\n\n    if(!postcssPath) {\n      log(`\\n${cliName} Error: PostCSS binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const postcssOptions: string[] = [\n      `${sourceDir}/**/**.css`,\n      '--base',\n      sourceDir,\n      '--dir',\n      outputDir,\n      '--config',\n      pathResolve(dirName, '../../postcss.config.js')\n    ];\n\n    try {\n      await execa(postcssPath, postcssOptions, {encoding: 'utf8'});\n      spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed formatting css.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const gifFiles: string[] = getFilesByExt('.gif', LexConfig.config);\n  const jpgFiles: string[] = getFilesByExt('.jpg', LexConfig.config);\n  const pngFiles: string[] = getFilesByExt('.png', LexConfig.config);\n  const svgFiles: string[] = getFilesByExt('.svg', LexConfig.config);\n  const imageFiles: string[] = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];\n\n  if(imageFiles.length) {\n    try {\n      await copyFiles(imageFiles, 'image', spinner, LexConfig.config);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move images to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const ttfFiles: string[] = getFilesByExt('.ttf', LexConfig.config);\n  const otfFiles: string[] = getFilesByExt('.otf', LexConfig.config);\n  const woffFiles: string[] = getFilesByExt('.woff', LexConfig.config);\n  const woff2Files: string[] = getFilesByExt('.woff2', LexConfig.config);\n  const fontFiles: string[] = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];\n\n  if(fontFiles.length) {\n    try {\n      await copyFiles(fontFiles, 'font', spinner, LexConfig.config);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move fonts to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const mdFiles: string[] = getFilesByExt('.md', LexConfig.config);\n\n  if(mdFiles.length) {\n    try {\n      await copyFiles(mdFiles, 'documents', spinner, LexConfig.config);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move docs to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  spinner.start(watch ? 'Watching for changes...' : 'Compiling with ESBuild...');\n\n  try {\n    await execa(esbuildPath, esbuildOptions, {encoding: 'utf8'});\n\n    spinner.succeed('Compile completed successfully!');\n  } catch (error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    if(!quiet) {\n      console.error(error);\n    }\n\n    spinner.fail('Code compiling failed.');\n\n    callback(1);\n    return 1;\n  }\n\n  try {\n    await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n  } catch (copyError) {\n    log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n\n    spinner.fail('Failed to copy configured files.');\n\n    callback(1);\n    return 1;\n  }\n\n  callback(0);\n  return 0;\n};"],
  "mappings": "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",
  "names": []
}

|
|
241
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/compile/compile.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 {execa} from 'execa';\nimport {existsSync, lstatSync, readdirSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {extname as pathExtname, join as pathJoin, resolve as pathResolve} from 'path';\n\nimport {LexConfig, getTypeScriptConfigPath} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, copyFiles, createSpinner, getFilesByExt, removeFiles} from '../../utils/app.js';\nimport {getDirName, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport const hasFileType = (startPath: string, ext: string[]): boolean => {\n  if(!existsSync(startPath)) {\n    return false;\n  }\n\n  const files: string[] = readdirSync(startPath);\n\n  return files.some((file: string) => {\n    const filename: string = pathJoin(startPath, file);\n    const fileExt: string = pathExtname(filename);\n    const stat = lstatSync(filename);\n\n    if(stat.isDirectory()) {\n      return hasFileType(filename, ext);\n    }\n\n    return ext.includes(fileExt);\n  });\n};\n\nexport const compile = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    outputPath,\n    quiet,\n    remove,\n    sourcePath,\n    watch\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} compiling...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, sourceFullPath, useTypescript} = LexConfig.config;\n  const outputDir: string = outputPath || outputFullPath;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';\n  const dirName = getDirName();\n  const dirPath: string = pathResolve(dirName, '../..');\n\n  checkLinkedModules();\n\n  if(remove) {\n    await removeFiles(outputDir);\n  }\n\n  if(useTypescript) {\n    LexConfig.checkCompileTypescriptConfig();\n\n    const typescriptPath: string = resolveBinaryPath('tsc', 'typescript');\n\n    if(!typescriptPath) {\n      log(`\\n${cliName} Error: TypeScript binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const typescriptOptions: string[] = config ?\n      ['-p', config] :\n      ['-p', getTypeScriptConfigPath('tsconfig.build.json')];\n\n    spinner.start('Static type checking with Typescript...');\n\n    try {\n      await execa(typescriptPath, typescriptOptions, {encoding: 'utf8'});\n\n      spinner.succeed('Successfully completed type checking!');\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Type checking failed.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const globOptions = {\n    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test|*.integration).ts*`, globOptions);\n  const jsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test|*.integration).js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n  const esbuildConfig = LexConfig.config.esbuild || {};\n  const isProduction = process.env.NODE_ENV === 'production';\n  let shouldMinify: boolean;\n\n  if(typeof esbuildConfig.minify === 'boolean') {\n    shouldMinify = esbuildConfig.minify;\n  } else {\n    shouldMinify = isProduction;\n  }\n\n  const esbuildPath: string = resolveBinaryPath('esbuild', 'esbuild');\n\n  if(!esbuildPath) {\n    log(`\\n${cliName} Error: esbuild binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your installation.', 'info', quiet);\n    return 1;\n  }\n\n  const esbuildOptions: string[] = [\n    ...sourceFiles,\n    '--color=true',\n    `--format=${esbuildConfig.format || 'esm'}`,\n    `--outdir=${outputDir}`,\n    `--platform=${esbuildConfig.platform || 'node'}`,\n    `--sourcemap=${esbuildConfig.sourcemap || 'inline'}`,\n    `--target=${esbuildConfig.target || 'node20'}`\n  ];\n\n  if(shouldMinify) {\n    esbuildOptions.push('--minify');\n  }\n\n  if(esbuildConfig.treeShaking !== false) {\n    esbuildOptions.push('--tree-shaking=true');\n  }\n\n  if(esbuildConfig.drop && esbuildConfig.drop.length > 0) {\n    esbuildConfig.drop.forEach((item) => {\n      esbuildOptions.push(`--drop:${item}`);\n    });\n  }\n\n  if(esbuildConfig.pure && esbuildConfig.pure.length > 0) {\n    esbuildConfig.pure.forEach((item) => {\n      esbuildOptions.push(`--pure:${item}`);\n    });\n  }\n\n  if(esbuildConfig.legalComments) {\n    esbuildOptions.push(`--legal-comments=${esbuildConfig.legalComments}`);\n  }\n\n  if(esbuildConfig.banner) {\n    Object.entries(esbuildConfig.banner).forEach(([type, content]) => {\n      esbuildOptions.push(`--banner:${type}=${content}`);\n    });\n  }\n\n  if(esbuildConfig.footer) {\n    Object.entries(esbuildConfig.footer).forEach(([type, content]) => {\n      esbuildOptions.push(`--footer:${type}=${content}`);\n    });\n  }\n\n  if(esbuildConfig.define) {\n    Object.entries(esbuildConfig.define).forEach(([key, value]) => {\n      esbuildOptions.push(`--define:${key}=${value}`);\n    });\n  }\n\n  if(watch) {\n    esbuildOptions.push('--watch');\n  }\n\n  const cssFiles: string[] = getFilesByExt('.css', LexConfig.config);\n\n  if(cssFiles.length) {\n    const postcssPath: string = resolveBinaryPath('postcss', 'postcss-cli');\n\n    if(!postcssPath) {\n      log(`\\n${cliName} Error: PostCSS binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const postcssOptions: string[] = [\n      `${sourceDir}/**/**.css`,\n      '--base',\n      sourceDir,\n      '--dir',\n      outputDir,\n      '--config',\n      pathResolve(dirName, '../../postcss.config.js')\n    ];\n\n    try {\n      await execa(postcssPath, postcssOptions, {encoding: 'utf8'});\n      spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed formatting css.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const gifFiles: string[] = getFilesByExt('.gif', LexConfig.config);\n  const jpgFiles: string[] = getFilesByExt('.jpg', LexConfig.config);\n  const pngFiles: string[] = getFilesByExt('.png', LexConfig.config);\n  const svgFiles: string[] = getFilesByExt('.svg', LexConfig.config);\n  const imageFiles: string[] = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];\n\n  if(imageFiles.length) {\n    try {\n      await copyFiles(imageFiles, 'image', spinner, LexConfig.config);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move images to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const ttfFiles: string[] = getFilesByExt('.ttf', LexConfig.config);\n  const otfFiles: string[] = getFilesByExt('.otf', LexConfig.config);\n  const woffFiles: string[] = getFilesByExt('.woff', LexConfig.config);\n  const woff2Files: string[] = getFilesByExt('.woff2', LexConfig.config);\n  const fontFiles: string[] = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];\n\n  if(fontFiles.length) {\n    try {\n      await copyFiles(fontFiles, 'font', spinner, LexConfig.config);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move fonts to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const mdFiles: string[] = getFilesByExt('.md', LexConfig.config);\n\n  if(mdFiles.length) {\n    try {\n      await copyFiles(mdFiles, 'documents', spinner, LexConfig.config);\n    } catch (error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move docs to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  spinner.start(watch ? 'Watching for changes...' : 'Compiling with ESBuild...');\n\n  try {\n    await execa(esbuildPath, esbuildOptions, {encoding: 'utf8'});\n\n    spinner.succeed('Compile completed successfully!');\n  } catch (error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    if(!quiet) {\n      console.error(error);\n    }\n\n    spinner.fail('Code compiling failed.');\n\n    callback(1);\n    return 1;\n  }\n\n  try {\n    await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n  } catch (copyError) {\n    log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n\n    spinner.fail('Failed to copy configured files.');\n\n    callback(1);\n    return 1;\n  }\n\n  callback(0);\n  return 0;\n};"],
  "mappings": "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",
  "names": []
}

|
|
@@ -1,17 +1,16 @@
|
|
|
1
1
|
export interface ServerlessOptions {
|
|
2
2
|
readonly cliName?: string;
|
|
3
3
|
readonly config?: string;
|
|
4
|
+
readonly debug?: boolean;
|
|
4
5
|
readonly host?: string;
|
|
5
6
|
readonly httpPort?: number;
|
|
6
7
|
readonly httpsPort?: number;
|
|
7
|
-
readonly wsPort?: number;
|
|
8
8
|
readonly quiet?: boolean;
|
|
9
9
|
readonly remove?: boolean;
|
|
10
|
-
readonly variables?: string;
|
|
11
|
-
readonly usePublicIp?: boolean;
|
|
12
|
-
readonly debug?: boolean;
|
|
13
|
-
readonly printOutput?: boolean;
|
|
14
10
|
readonly test?: boolean;
|
|
11
|
+
readonly usePublicIp?: boolean;
|
|
12
|
+
readonly variables?: string;
|
|
13
|
+
readonly wsPort?: number;
|
|
15
14
|
}
|
|
16
15
|
export type ServerlessCallback = (status: number) => void;
|
|
17
16
|
export declare const serverless: (cmd: ServerlessOptions, callback?: ServerlessCallback) => Promise<number>;
|
|
@@ -2,7 +2,7 @@ import boxen from "boxen";
|
|
|
2
2
|
import chalk from "chalk";
|
|
3
3
|
import express from "express";
|
|
4
4
|
import { readFileSync, existsSync, mkdirSync, writeFileSync } from "fs";
|
|
5
|
-
import {
|
|
5
|
+
import { homedir } from "os";
|
|
6
6
|
import { resolve as pathResolve, join } from "path";
|
|
7
7
|
import { WebSocketServer } from "ws";
|
|
8
8
|
import { LexConfig } from "../../LexConfig.js";
|
|
@@ -57,35 +57,6 @@ const fetchPublicIp = (forceRefresh = false) => new Promise((resolve) => {
|
|
|
57
57
|
resolve(ip);
|
|
58
58
|
}).catch(() => resolve(void 0));
|
|
59
59
|
});
|
|
60
|
-
const getNetworkAddresses = () => {
|
|
61
|
-
const interfaces = networkInterfaces();
|
|
62
|
-
const addresses = {
|
|
63
|
-
local: "localhost",
|
|
64
|
-
private: null,
|
|
65
|
-
public: null
|
|
66
|
-
};
|
|
67
|
-
for (const name of Object.keys(interfaces)) {
|
|
68
|
-
const networkInterface = interfaces[name];
|
|
69
|
-
if (!networkInterface) {
|
|
70
|
-
continue;
|
|
71
|
-
}
|
|
72
|
-
for (const iface of networkInterface) {
|
|
73
|
-
if (iface.family === "IPv4" && !iface.internal) {
|
|
74
|
-
const ip = iface.address;
|
|
75
|
-
if (ip.startsWith("10.") || ip.startsWith("192.168.") || ip.startsWith("172.")) {
|
|
76
|
-
if (!addresses.private) {
|
|
77
|
-
addresses.private = ip;
|
|
78
|
-
}
|
|
79
|
-
} else {
|
|
80
|
-
if (!addresses.public) {
|
|
81
|
-
addresses.public = ip;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
return addresses;
|
|
88
|
-
};
|
|
89
60
|
const displayServerStatus = (httpPort, httpsPort, wsPort, host, quiet, publicIp) => {
|
|
90
61
|
if (quiet) {
|
|
91
62
|
return;
|
|
@@ -113,11 +84,11 @@ ${chalk.green("Public:")} ${chalk.underline(`http://${publicIp}:${httpPort}`)
|
|
|
113
84
|
${urlLines}
|
|
114
85
|
${chalk.yellow("Press Ctrl+C to stop the server")}`,
|
|
115
86
|
{
|
|
116
|
-
|
|
117
|
-
margin: 1,
|
|
118
|
-
borderStyle: "round",
|
|
87
|
+
backgroundColor: "#1a1a1a",
|
|
119
88
|
borderColor: "cyan",
|
|
120
|
-
|
|
89
|
+
borderStyle: "round",
|
|
90
|
+
margin: 1,
|
|
91
|
+
padding: 1
|
|
121
92
|
}
|
|
122
93
|
);
|
|
123
94
|
console.log(`
|
|
@@ -188,7 +159,7 @@ const captureConsoleLogs = (handler, quiet) => {
|
|
|
188
159
|
}
|
|
189
160
|
};
|
|
190
161
|
};
|
|
191
|
-
const createExpressServer = async (config, outputDir, httpPort, host, quiet, debug
|
|
162
|
+
const createExpressServer = async (config, outputDir, httpPort, host, quiet, debug) => {
|
|
192
163
|
const app = express();
|
|
193
164
|
app.use((req, res, next) => {
|
|
194
165
|
res.header("Access-Control-Allow-Origin", "*");
|
|
@@ -272,25 +243,24 @@ const createExpressServer = async (config, outputDir, httpPort, host, quiet, deb
|
|
|
272
243
|
originalConsoleLog(`[GraphQL] ${logMessage}`);
|
|
273
244
|
};
|
|
274
245
|
const context = {
|
|
275
|
-
|
|
276
|
-
res,
|
|
246
|
+
awsRequestId: "test-request-id",
|
|
277
247
|
functionName: "graphql",
|
|
278
248
|
functionVersion: "$LATEST",
|
|
249
|
+
getRemainingTimeInMillis: () => 3e4,
|
|
279
250
|
invokedFunctionArn: "arn:aws:lambda:us-east-1:123456789012:function:graphql",
|
|
280
|
-
memoryLimitInMB: "128",
|
|
281
|
-
awsRequestId: "test-request-id",
|
|
282
251
|
logGroupName: "/aws/lambda/graphql",
|
|
283
252
|
logStreamName: "test-log-stream",
|
|
284
|
-
|
|
253
|
+
req,
|
|
254
|
+
res
|
|
285
255
|
};
|
|
286
256
|
const wrappedHandler = captureConsoleLogs(graphqlHandler, quiet);
|
|
287
257
|
try {
|
|
288
258
|
const result = await wrappedHandler({
|
|
259
|
+
body: JSON.stringify(req.body),
|
|
260
|
+
headers: req.headers,
|
|
289
261
|
httpMethod: "POST",
|
|
290
262
|
path: graphqlPath,
|
|
291
|
-
|
|
292
|
-
queryStringParameters: {},
|
|
293
|
-
body: JSON.stringify(req.body)
|
|
263
|
+
queryStringParameters: {}
|
|
294
264
|
}, context);
|
|
295
265
|
console.log = originalConsoleLog;
|
|
296
266
|
if (result && typeof result === "object" && result.statusCode) {
|
|
@@ -319,7 +289,8 @@ const createExpressServer = async (config, outputDir, httpPort, host, quiet, deb
|
|
|
319
289
|
try {
|
|
320
290
|
const url = req.url || "/";
|
|
321
291
|
const method = req.method || "GET";
|
|
322
|
-
|
|
292
|
+
const pathname = req.path || url.split("?")[0];
|
|
293
|
+
log(`${method} ${url} (pathname: ${pathname})`, "info", false);
|
|
323
294
|
let matchedFunction = null;
|
|
324
295
|
if (config.functions) {
|
|
325
296
|
for (const [functionName, functionConfig] of Object.entries(config.functions)) {
|
|
@@ -328,7 +299,7 @@ const createExpressServer = async (config, outputDir, httpPort, host, quiet, deb
|
|
|
328
299
|
if (event.http) {
|
|
329
300
|
const eventPath = event.http.path || "/";
|
|
330
301
|
const eventMethod = event.http.method || "GET";
|
|
331
|
-
if (eventPath && eventPath ===
|
|
302
|
+
if (eventPath && eventPath === pathname && eventMethod === method) {
|
|
332
303
|
matchedFunction = functionName;
|
|
333
304
|
break;
|
|
334
305
|
}
|
|
@@ -353,14 +324,14 @@ const createExpressServer = async (config, outputDir, httpPort, host, quiet, deb
|
|
|
353
324
|
queryStringParameters: req.query
|
|
354
325
|
};
|
|
355
326
|
const context = {
|
|
327
|
+
awsRequestId: "test-request-id",
|
|
356
328
|
functionName: matchedFunction,
|
|
357
329
|
functionVersion: "$LATEST",
|
|
330
|
+
getRemainingTimeInMillis: () => 3e4,
|
|
358
331
|
invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,
|
|
359
|
-
memoryLimitInMB: "128",
|
|
360
|
-
awsRequestId: "test-request-id",
|
|
361
332
|
logGroupName: `/aws/lambda/${matchedFunction}`,
|
|
362
333
|
logStreamName: "test-log-stream",
|
|
363
|
-
|
|
334
|
+
memoryLimitInMB: "128"
|
|
364
335
|
};
|
|
365
336
|
try {
|
|
366
337
|
const result = await wrappedHandler(event, context);
|
|
@@ -392,7 +363,7 @@ const createExpressServer = async (config, outputDir, httpPort, host, quiet, deb
|
|
|
392
363
|
});
|
|
393
364
|
return app;
|
|
394
365
|
};
|
|
395
|
-
const createWebSocketServer = (config, outputDir, wsPort, quiet, debug
|
|
366
|
+
const createWebSocketServer = (config, outputDir, wsPort, quiet, debug) => {
|
|
396
367
|
const wss = new WebSocketServer({ port: wsPort });
|
|
397
368
|
wss.on("connection", async (ws, req) => {
|
|
398
369
|
log(`WebSocket connection established: ${req.url}`, "info", false);
|
|
@@ -423,24 +394,24 @@ const createWebSocketServer = (config, outputDir, wsPort, quiet, debug, printOut
|
|
|
423
394
|
if (handler) {
|
|
424
395
|
const wrappedHandler = captureConsoleLogs(handler, quiet);
|
|
425
396
|
const event = {
|
|
397
|
+
body: data.body || null,
|
|
426
398
|
requestContext: {
|
|
427
|
-
routeKey: data.action || "$default",
|
|
428
|
-
connectionId: "test-connection-id",
|
|
429
399
|
apiGateway: {
|
|
430
400
|
endpoint: `ws://localhost:${wsPort}`
|
|
431
|
-
}
|
|
432
|
-
|
|
433
|
-
|
|
401
|
+
},
|
|
402
|
+
connectionId: "test-connection-id",
|
|
403
|
+
routeKey: data.action || "$default"
|
|
404
|
+
}
|
|
434
405
|
};
|
|
435
406
|
const context = {
|
|
407
|
+
awsRequestId: "test-request-id",
|
|
436
408
|
functionName: matchedFunction,
|
|
437
409
|
functionVersion: "$LATEST",
|
|
410
|
+
getRemainingTimeInMillis: () => 3e4,
|
|
438
411
|
invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,
|
|
439
|
-
memoryLimitInMB: "128",
|
|
440
|
-
awsRequestId: "test-request-id",
|
|
441
412
|
logGroupName: `/aws/lambda/${matchedFunction}`,
|
|
442
413
|
logStreamName: "test-log-stream",
|
|
443
|
-
|
|
414
|
+
memoryLimitInMB: "128"
|
|
444
415
|
};
|
|
445
416
|
const result = await wrappedHandler(event, context);
|
|
446
417
|
if (result && typeof result === "object" && result.statusCode) {
|
|
@@ -498,17 +469,16 @@ const serverless = async (cmd, callback = () => ({})) => {
|
|
|
498
469
|
const {
|
|
499
470
|
cliName = "Lex",
|
|
500
471
|
config,
|
|
472
|
+
debug = false,
|
|
501
473
|
host = "localhost",
|
|
502
474
|
httpPort = 3e3,
|
|
503
475
|
httpsPort = 3001,
|
|
504
|
-
wsPort = 3002,
|
|
505
476
|
quiet = false,
|
|
506
477
|
remove = false,
|
|
478
|
+
test = false,
|
|
507
479
|
usePublicIp,
|
|
508
480
|
variables,
|
|
509
|
-
|
|
510
|
-
printOutput = false,
|
|
511
|
-
test = false
|
|
481
|
+
wsPort = 3002
|
|
512
482
|
} = cmd;
|
|
513
483
|
const spinner = createSpinner(quiet);
|
|
514
484
|
log(`${cliName} starting serverless development server...`, "info", quiet);
|
|
@@ -569,11 +539,11 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
569
539
|
...serverlessConfig,
|
|
570
540
|
custom: {
|
|
571
541
|
"serverless-offline": {
|
|
542
|
+
cors: serverlessConfig.custom?.["serverless-offline"]?.cors !== false,
|
|
543
|
+
host: serverlessConfig.custom?.["serverless-offline"]?.host || host,
|
|
572
544
|
httpPort: serverlessConfig.custom?.["serverless-offline"]?.httpPort || httpPort,
|
|
573
545
|
httpsPort: serverlessConfig.custom?.["serverless-offline"]?.httpsPort || httpsPort,
|
|
574
|
-
wsPort: serverlessConfig.custom?.["serverless-offline"]?.wsPort || wsPort
|
|
575
|
-
host: serverlessConfig.custom?.["serverless-offline"]?.host || host,
|
|
576
|
-
cors: serverlessConfig.custom?.["serverless-offline"]?.cors !== false
|
|
546
|
+
wsPort: serverlessConfig.custom?.["serverless-offline"]?.wsPort || wsPort
|
|
577
547
|
}
|
|
578
548
|
}
|
|
579
549
|
};
|
|
@@ -592,16 +562,14 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
592
562
|
httpPort2,
|
|
593
563
|
host2,
|
|
594
564
|
quiet,
|
|
595
|
-
debug
|
|
596
|
-
printOutput
|
|
565
|
+
debug
|
|
597
566
|
);
|
|
598
567
|
const wsServer = createWebSocketServer(
|
|
599
568
|
finalConfig,
|
|
600
569
|
outputDir,
|
|
601
570
|
wsPort2,
|
|
602
571
|
quiet,
|
|
603
|
-
debug
|
|
604
|
-
printOutput
|
|
572
|
+
debug
|
|
605
573
|
);
|
|
606
574
|
wsServer.on("error", (error) => {
|
|
607
575
|
log(`WebSocket server error: ${error.message}`, "error", quiet);
|
|
@@ -659,4 +627,4 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
659
627
|
export {
|
|
660
628
|
serverless
|
|
661
629
|
};
|
|
662
|
-
//# 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 {networkInterfaces, homedir} from 'os';\nimport {resolve as pathResolve, join} from 'path';\nimport {WebSocketServer} from 'ws';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, removeFiles} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface ServerlessOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly host?: string;\n  readonly httpPort?: number;\n  readonly httpsPort?: number;\n  readonly wsPort?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly variables?: string;\n  readonly usePublicIp?: boolean;\n  readonly debug?: boolean;\n  readonly printOutput?: boolean;\n  readonly test?: boolean;\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 path?: string;\n      readonly method?: string;\n      readonly cors?: boolean;\n    };\n    readonly websocket?: {\n      readonly route?: string;\n    };\n  }>;\n}\n\ninterface ServerlessConfig {\n  readonly functions?: Record<string, ServerlessHandler>;\n  readonly custom?: {\n    readonly 'serverless-offline'?: {\n      readonly httpPort?: number;\n      readonly httpsPort?: number;\n      readonly wsPort?: number;\n      readonly host?: string;\n      readonly cors?: boolean;\n    };\n  };\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 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 = (\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('\uD83D\uDE80 Serverless Development Server Running')}\\n\\n${urlLines}\\n` +\n    `${chalk.yellow('Press Ctrl+C to stop the server')}`,\n    {\n      padding: 1,\n      margin: 1,\n      borderStyle: 'round',\n      borderColor: 'cyan',\n      backgroundColor: '#1a1a1a'\n    }\n  );\n\n  console.log(`\\n${statusBox}\\n`);\n};\n\nconst loadHandler = async (handlerPath: string, outputDir: string) => {\n  try {\n    const fullPath = pathResolve(outputDir, handlerPath);\n    log(`Loading handler from: ${fullPath}`, 'info', false);\n\n    if(!existsSync(fullPath)) {\n      throw new Error(`Handler file not found: ${fullPath}`);\n    }\n\n    // Dynamic import of the handler with better error handling\n    try {\n      const handlerModule = await import(fullPath);\n      log(`Handler module loaded: ${Object.keys(handlerModule)}`, 'info', false);\n\n      const handler = handlerModule.default || handlerModule.handler || handlerModule;\n      log(`Handler found: ${typeof handler}`, 'info', false);\n\n      return handler;\n    } catch (importError) {\n      log(`Import error for handler ${handlerPath}: ${importError.message}`, 'error', false);\n      return null;\n    }\n  } catch (error) {\n    log(`Error loading handler ${handlerPath}: ${error.message}`, 'error', false);\n    return null;\n  }\n};\n\nconst captureConsoleLogs = (handler: Function, 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 (config: ServerlessConfig, outputDir: string, httpPort: number, host: string, quiet: boolean, debug: boolean, printOutput: boolean) => {\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('\uD83D\uDD0D GraphQL Debug Mode: Analyzing request...', 'info', false);\n          log(`\uD83D\uDCDD GraphQL Query: ${req.body.query}`, 'info', false);\n          if(req.body.variables) {\n            log(`\uD83D\uDCCA GraphQL Variables: ${JSON.stringify(req.body.variables, null, 2)}`, 'info', false);\n          }\n          if(req.body.operationName) {\n            log(`\uD83C\uDFF7\uFE0F  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          req,\n          res,\n          functionName: 'graphql',\n          functionVersion: '$LATEST',\n          invokedFunctionArn: 'arn:aws:lambda:us-east-1:123456789012:function:graphql',\n          memoryLimitInMB: '128',\n          awsRequestId: 'test-request-id',\n          logGroupName: '/aws/lambda/graphql',\n          logStreamName: 'test-log-stream',\n          getRemainingTimeInMillis: () => 30000\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            httpMethod: 'POST',\n            path: graphqlPath,\n            headers: req.headers,\n            queryStringParameters: {},\n            body: JSON.stringify(req.body)\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\n      log(`${method} ${url}`, 'info', false);\n\n      // Find matching function\n      let matchedFunction = null;\n\n      if(config.functions) {\n        for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event.http) {\n                const eventPath = event.http.path || '/';\n                const eventMethod = event.http.method || 'GET';\n\n                // Simple path matching - avoid complex regex\n                if(eventPath && eventPath === url && eventMethod === method) {\n                  matchedFunction = functionName;\n                  break;\n                }\n              }\n            }\n          }\n          if(matchedFunction) {\n            break;\n          }\n        }\n      }\n\n      if(matchedFunction && config.functions[matchedFunction]) {\n        // Resolve handler path relative to output directory\n        const handlerPath = config.functions[matchedFunction].handler;\n        const handler = await loadHandler(handlerPath, outputDir);\n\n        if(handler) {\n          const wrappedHandler = captureConsoleLogs(handler, quiet);\n\n          const event = {\n            body: req.body,\n            headers: req.headers,\n            httpMethod: method,\n            path: url,\n            queryStringParameters: req.query\n          };\n\n          const context = {\n            functionName: matchedFunction,\n            functionVersion: '$LATEST',\n            invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n            memoryLimitInMB: '128',\n            awsRequestId: 'test-request-id',\n            logGroupName: `/aws/lambda/${matchedFunction}`,\n            logStreamName: 'test-log-stream',\n            getRemainingTimeInMillis: () => 30000\n          };\n\n          try {\n            const result = await wrappedHandler(event, context);\n\n            if(result && typeof result === 'object' && result.statusCode) {\n              res.status(result.statusCode);\n              if(result.headers) {\n                Object.entries(result.headers).forEach(([key, value]) => {\n                  res.setHeader(key, String(value));\n                });\n              }\n              res.send(result.body);\n            } else {\n              res.json(result);\n            }\n          } catch (error) {\n            log(`Handler error: ${error.message}`, 'error', false);\n            res.status(500).json({error: error.message});\n          }\n        } else {\n          res.status(404).json({error: 'Handler not found'});\n        }\n      } else {\n        res.status(404).json({error: 'Function not found'});\n      }\n    } catch (error) {\n      log(`Route handling error: ${error.message}`, 'error', false);\n      res.status(500).json({error: error.message});\n    }\n  });\n\n  return app;\n};\n\nconst createWebSocketServer = (config: ServerlessConfig, outputDir: string, wsPort: number, quiet: boolean, debug: boolean, printOutput: boolean) => {\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              requestContext: {\n                routeKey: data.action || '$default',\n                connectionId: 'test-connection-id',\n                apiGateway: {\n                  endpoint: `ws://localhost:${wsPort}`\n                }\n              },\n              body: data.body || null\n            };\n\n            const context = {\n              functionName: matchedFunction,\n              functionVersion: '$LATEST',\n              invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n              memoryLimitInMB: '128',\n              awsRequestId: 'test-request-id',\n              logGroupName: `/aws/lambda/${matchedFunction}`,\n              logStreamName: 'test-log-stream',\n              getRemainingTimeInMillis: () => 30000\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 (cmd: ServerlessOptions, callback: ServerlessCallback = () => ({})): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    host = 'localhost',\n    httpPort = 3000,\n    httpsPort = 3001,\n    wsPort = 3002,\n    quiet = false,\n    remove = false,\n    usePublicIp,\n    variables,\n    debug = false,\n    printOutput = false,\n    test = false\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} starting serverless development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath} = LexConfig.config;\n\n  // Load environment variables from .env files\n  const envPaths = [\n    pathResolve(process.cwd(), '.env'),\n    pathResolve(process.cwd(), '.env.local'),\n    pathResolve(process.cwd(), '.env.development')\n  ];\n\n  let envVars: Record<string, string> = {};\n\n  // Load from .env files in order (later files override earlier ones)\n  for(const envPath of envPaths) {\n    const fileEnvVars = loadEnvFile(envPath);\n    if(Object.keys(fileEnvVars).length > 0) {\n      log(`Loaded environment variables from: ${envPath}`, 'info', quiet);\n    }\n    envVars = {...envVars, ...fileEnvVars};\n  }\n\n  // Start with default NODE_ENV and loaded .env variables\n  let variablesObj: object = {NODE_ENV: 'development', ...envVars};\n\n  // Override with command line variables if provided\n  if(variables) {\n    try {\n      const cliVars = JSON.parse(variables);\n      variablesObj = {...variablesObj, ...cliVars};\n    } catch (_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  // If in test mode, exit early after loading environment variables\n  if(test) {\n    log('Test mode: Environment variables loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n    await removeFiles(outputFullPath || '');\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  // Load serverless configuration\n  let serverlessConfig: ServerlessConfig = {};\n\n  try {\n    const configPath = config || pathResolve(process.cwd(), 'lex.config.mjs');\n    log(`Loading serverless config from: ${configPath}`, 'info', quiet);\n\n    if(existsSync(configPath)) {\n      const configModule = await import(configPath);\n      serverlessConfig = configModule.default?.serverless || configModule.serverless || {};\n      log('Serverless config loaded successfully', 'info', quiet);\n      log(`Loaded functions: ${Object.keys(serverlessConfig.functions || {}).join(', ')}`, 'info', quiet);\n    } else {\n      log(`No serverless config found at ${configPath}, using defaults`, 'warn', quiet);\n    }\n  } catch (error) {\n    log(`Error loading serverless config: ${error.message}`, 'error', quiet);\n    // Don't exit, continue with empty config\n  }\n\n  // Merge config with command line options\n  const finalConfig: ServerlessConfig = {\n    ...serverlessConfig,\n    custom: {\n      'serverless-offline': {\n        httpPort: serverlessConfig.custom?.['serverless-offline']?.httpPort || httpPort,\n        httpsPort: serverlessConfig.custom?.['serverless-offline']?.httpsPort || httpsPort,\n        wsPort: serverlessConfig.custom?.['serverless-offline']?.wsPort || wsPort,\n        host: serverlessConfig.custom?.['serverless-offline']?.host || host,\n        cors: serverlessConfig.custom?.['serverless-offline']?.cors !== false\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      printOutput\n    );\n\n    // Create WebSocket server\n    const wsServer = createWebSocketServer(\n      finalConfig,\n      outputDir,\n      wsPort,\n      quiet,\n      debug,\n      printOutput\n    );\n\n    // Handle server errors\n    wsServer.on('error', (error) => {\n      log(`WebSocket server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start WebSocket server.');\n      callback(1);\n      return;\n    });\n\n    // Start Express server\n    const server = expressApp.listen(httpPort, host, () => {\n      spinner.succeed('Serverless development server started.');\n\n      displayServerStatus(\n        httpPort,\n        finalConfig.custom!['serverless-offline']!.httpsPort!,\n        wsPort,\n        host,\n        quiet\n      );\n\n      fetchPublicIp(usePublicIp).then((publicIp) => {\n        if(publicIp) {\n          displayServerStatus(\n            httpPort,\n            finalConfig.custom!['serverless-offline']!.httpsPort!,\n            wsPort,\n            host,\n            quiet,\n            publicIp\n          );\n        }\n      });\n    });\n\n    // Handle Express server errors\n    server.on('error', (error) => {\n      log(`Express server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start Express server.');\n      callback(1);\n      return;\n    });\n\n    // Handle graceful shutdown\n    const shutdown = () => {\n      log('\\nShutting down serverless development server...', 'info', quiet);\n      server.close();\n      wsServer.close();\n      callback(0);\n    };\n\n    process.on('SIGINT', shutdown);\n    process.on('SIGTERM', shutdown);\n\n    // Keep the process alive\n    process.stdin.resume();\n\n    log('Serverless development server is running. Press Ctrl+C to stop.', 'info', quiet);\n\n    // Don't call callback here, let the process stay alive\n    return 0;\n  } catch (error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('Failed to start serverless development server.');\n    callback(1);\n    return 1;\n  }\n};"],
  "mappings": "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",
  "names": ["log", "httpPort", "wsPort", "host"]
}

|
|
630
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/serverless/serverless.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport express from 'express';\nimport {readFileSync, existsSync, mkdirSync, writeFileSync} from 'fs';\nimport {homedir} from 'os';\nimport {resolve as pathResolve, join} from 'path';\nimport {WebSocketServer} from 'ws';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, removeFiles} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface ServerlessOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly host?: string;\n  readonly httpPort?: number;\n  readonly httpsPort?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly test?: boolean;\n  readonly usePublicIp?: boolean;\n  readonly variables?: string;\n  readonly wsPort?: number;\n}\n\nexport type ServerlessCallback = (status: number) => void;\n\ninterface PublicIpCache {\n  ip: string;\n  timestamp: number;\n}\n\ninterface ServerlessHandler {\n  readonly handler: string;\n  readonly events?: Array<{\n    readonly http?: {\n      readonly cors?: boolean;\n      readonly method?: string;\n      readonly path?: string;\n    };\n    readonly websocket?: {\n      readonly route?: string;\n    };\n  }>;\n}\n\ninterface ServerlessConfig {\n  readonly custom?: {\n    readonly 'serverless-offline'?: {\n      readonly cors?: boolean;\n      readonly host?: string;\n      readonly httpPort?: number;\n      readonly httpsPort?: number;\n      readonly wsPort?: number;\n    };\n  };\n  readonly functions?: Record<string, ServerlessHandler>;\n}\n\nconst getCacheDir = (): string => {\n  const cacheDir = join(homedir(), '.lex-cache');\n  if(!existsSync(cacheDir)) {\n    mkdirSync(cacheDir, {recursive: true});\n  }\n  return cacheDir;\n};\n\nconst getCachePath = (): string => join(getCacheDir(), 'public-ip.json');\n\nconst readPublicIpCache = (): PublicIpCache | null => {\n  const cachePath = getCachePath();\n  if(!existsSync(cachePath)) {\n    return null;\n  }\n\n  try {\n    const cacheData = readFileSync(cachePath, 'utf8');\n    const cache: PublicIpCache = JSON.parse(cacheData);\n\n    // Check if cache is older than 1 week\n    const oneWeekMs = 7 * 24 * 60 * 60 * 1000;\n    if(Date.now() - cache.timestamp > oneWeekMs) {\n      return null;\n    }\n\n    return cache;\n  } catch {\n    return null;\n  }\n};\n\nconst writePublicIpCache = (ip: string): void => {\n  const cachePath = getCachePath();\n  const cache: PublicIpCache = {\n    ip,\n    timestamp: Date.now()\n  };\n  writeFileSync(cachePath, JSON.stringify(cache, null, 2));\n};\n\nconst fetchPublicIp = (forceRefresh: boolean = false): Promise<string | undefined> => new Promise((resolve) => {\n  if(!forceRefresh) {\n    const cached = readPublicIpCache();\n    if(cached) {\n      resolve(cached.ip);\n      return;\n    }\n  }\n\n  // Use fetch instead of https\n  fetch('https://api.ipify.org')\n    .then((res) => res.text())\n    .then((data) => {\n      const ip = data.trim();\n      if(ip) {\n        writePublicIpCache(ip);\n      }\n      resolve(ip);\n    })\n    .catch(() => resolve(undefined));\n});\n\nconst displayServerStatus = (\n  httpPort: number,\n  httpsPort: number,\n  wsPort: number,\n  host: string,\n  quiet: boolean,\n  publicIp?: string\n) => {\n  if(quiet) {\n    return;\n  }\n\n  const httpUrl = `http://${host}:${httpPort}`;\n  const httpsUrl = `https://${host}:${httpsPort}`;\n  const wsUrl = `ws://${host}:${wsPort}`;\n  const wssUrl = `wss://${host}:${wsPort}`;\n\n  let urlLines = `${chalk.green('HTTP:')}      ${chalk.underline(httpUrl)}\\n`;\n  urlLines += `${chalk.green('HTTPS:')}     ${chalk.underline(httpsUrl)}\\n`;\n  urlLines += `${chalk.green('WebSocket:')} ${chalk.underline(wsUrl)}\\n`;\n  urlLines += `${chalk.green('WSS:')}       ${chalk.underline(wssUrl)}\\n`;\n\n  if(publicIp) {\n    urlLines += `\\n${chalk.green('Public:')}    ${chalk.underline(`http://${publicIp}:${httpPort}`)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('\uD83D\uDE80 Serverless Development Server Running')}\\n\\n${urlLines}\\n` +\n    `${chalk.yellow('Press Ctrl+C to stop the server')}`,\n    {\n      backgroundColor: '#1a1a1a',\n      borderColor: 'cyan',\n      borderStyle: 'round',\n      margin: 1,\n      padding: 1\n    }\n  );\n\n  console.log(`\\n${statusBox}\\n`);\n};\n\nconst loadHandler = async (handlerPath: string, outputDir: string) => {\n  try {\n    const fullPath = pathResolve(outputDir, handlerPath);\n    log(`Loading handler from: ${fullPath}`, 'info', false);\n\n    if(!existsSync(fullPath)) {\n      throw new Error(`Handler file not found: ${fullPath}`);\n    }\n\n    // Dynamic import of the handler with better error handling\n    try {\n      const handlerModule = await import(fullPath);\n      log(`Handler module loaded: ${Object.keys(handlerModule)}`, 'info', false);\n\n      const handler = handlerModule.default || handlerModule.handler || handlerModule;\n      log(`Handler found: ${typeof handler}`, 'info', false);\n\n      return handler;\n    } catch (importError) {\n      log(`Import error for handler ${handlerPath}: ${importError.message}`, 'error', false);\n      return null;\n    }\n  } catch (error) {\n    log(`Error loading handler ${handlerPath}: ${error.message}`, 'error', false);\n    return null;\n  }\n};\n\nconst captureConsoleLogs = (handler: (event: any, context: any) => Promise<any>, quiet: boolean) => {\n  if(quiet) {\n    return handler;\n  }\n\n  return async (event: any, context: any) => {\n    // Capture console.log, console.error, etc.\n    const originalConsoleLog = console.log;\n    const originalConsoleError = console.error;\n    const originalConsoleWarn = console.warn;\n    const originalConsoleInfo = console.info;\n\n    const logs: string[] = [];\n\n    console.log = (...args: any[]) => {\n      logs.push(`[LOG] ${args.join(' ')}`);\n      originalConsoleLog(...args);\n    };\n\n    console.error = (...args: any[]) => {\n      logs.push(`[ERROR] ${args.join(' ')}`);\n      originalConsoleError(...args);\n    };\n\n    console.warn = (...args: any[]) => {\n      logs.push(`[WARN] ${args.join(' ')}`);\n      originalConsoleWarn(...args);\n    };\n\n    console.info = (...args: any[]) => {\n      logs.push(`[INFO] ${args.join(' ')}`);\n      originalConsoleInfo(...args);\n    };\n\n    try {\n      const result = await handler(event, context);\n\n      // Output captured logs\n      if(logs.length > 0) {\n        console.log(chalk.gray('--- Handler Console Output ---'));\n        logs.forEach((log) => console.log(chalk.gray(log)));\n        console.log(chalk.gray('--- End Handler Console Output ---'));\n      }\n\n      return result;\n    } finally {\n      // Restore original console methods\n      console.log = originalConsoleLog;\n      console.error = originalConsoleError;\n      console.warn = originalConsoleWarn;\n      console.info = originalConsoleInfo;\n    }\n  };\n};\n\nconst createExpressServer = async (\n  config: ServerlessConfig,\n  outputDir: string,\n  httpPort: number,\n  host: string,\n  quiet: boolean,\n  debug: boolean\n) => {\n  const app = express();\n\n  // Enable CORS\n  app.use((req, res, next) => {\n    res.header('Access-Control-Allow-Origin', '*');\n    res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, PATCH, OPTIONS');\n    res.header('Access-Control-Allow-Headers', '*');\n    res.header('Access-Control-Allow-Credentials', 'true');\n\n    if(req.method === 'OPTIONS') {\n      res.sendStatus(200);\n    } else {\n      next();\n    }\n  });\n\n  // Parse JSON bodies\n  app.use(express.json());\n\n  // Load GraphQL handler\n  const loadGraphQLSchema = async () => {\n    try {\n      // Try to find a GraphQL handler\n      let graphqlHandler = null;\n\n      if(config.functions) {\n        for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event.http && event.http.path) {\n                // Look for GraphQL endpoints\n                if(event.http.path === '/public' || event.http.path === '/graphql') {\n                  graphqlHandler = await loadHandler(functionConfig.handler, outputDir);\n                  break;\n                }\n              }\n            }\n          }\n          if(graphqlHandler) {\n            break;\n          }\n        }\n      }\n\n      if(graphqlHandler) {\n        log('Found GraphQL handler', 'info', quiet);\n        return graphqlHandler;\n      }\n      return null;\n    } catch (error) {\n      log(`Error loading GraphQL handler: ${error.message}`, 'error', quiet);\n      return null;\n    }\n  };\n\n  // Set up GraphQL handler for GraphQL requests\n  try {\n    const graphqlHandler = await loadGraphQLSchema();\n    if(graphqlHandler) {\n      // Find the GraphQL path from the serverless config\n      let graphqlPath = '/graphql'; // default fallback\n\n      if(config.functions) {\n        for(const [_functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event?.http?.path) {\n                graphqlPath = event.http.path;\n                break;\n              }\n            }\n          }\n          if(graphqlPath !== '/graphql') {\n            break;\n          }\n        }\n      }\n\n      // Set up GraphQL endpoint with enhanced console.log capture\n      app.use(graphqlPath, async (req, res) => {\n        // GraphQL Debug Logging\n        if(debug && req.body && req.body.query) {\n          log('\uD83D\uDD0D GraphQL Debug Mode: Analyzing request...', 'info', false);\n          log(`\uD83D\uDCDD GraphQL Query: ${req.body.query}`, 'info', false);\n          if(req.body.variables) {\n            log(`\uD83D\uDCCA GraphQL Variables: ${JSON.stringify(req.body.variables, null, 2)}`, 'info', false);\n          }\n          if(req.body.operationName) {\n            log(`\uD83C\uDFF7\uFE0F  GraphQL Operation: ${req.body.operationName}`, 'info', false);\n          }\n        }\n\n        // Enhanced console.log capture\n        const originalConsoleLog = console.log;\n        const logs: string[] = [];\n\n        console.log = (...args) => {\n          const logMessage = args.map((arg) =>\n            (typeof arg === 'object' ? JSON.stringify(arg, null, 2) : String(arg))\n          ).join(' ');\n          logs.push(logMessage);\n          originalConsoleLog(`[GraphQL] ${logMessage}`);\n        };\n\n        // Create context for the handler\n        const context = {\n          awsRequestId: 'test-request-id',\n          functionName: 'graphql',\n          functionVersion: '$LATEST',\n          getRemainingTimeInMillis: () => 30000,\n          invokedFunctionArn: 'arn:aws:lambda:us-east-1:123456789012:function:graphql',\n          logGroupName: '/aws/lambda/graphql',\n          logStreamName: 'test-log-stream',\n          req,\n          res\n        };\n\n        // Wrap handler with console log capture\n        const wrappedHandler = captureConsoleLogs(graphqlHandler, quiet);\n\n        try {\n          // Call the handler with GraphQL parameters\n          const result = await wrappedHandler({\n            body: JSON.stringify(req.body),\n            headers: req.headers,\n            httpMethod: 'POST',\n            path: graphqlPath,\n            queryStringParameters: {}\n          }, context);\n\n          // Restore console.log\n          console.log = originalConsoleLog;\n\n          // Handle the result\n          if(result && typeof result === 'object' && result.statusCode) {\n            res.status(result.statusCode);\n            if(result.headers) {\n              Object.entries(result.headers).forEach(([key, value]) => {\n                res.setHeader(key, String(value));\n              });\n            }\n            res.send(result.body);\n          } else {\n            res.json(result);\n          }\n        } catch (error) {\n          // Restore console.log\n          console.log = originalConsoleLog;\n          log(`GraphQL handler error: ${error.message}`, 'error', false);\n          res.status(500).json({error: error.message});\n        }\n      });\n\n      log(`GraphQL endpoint available at http://${host}:${httpPort}${graphqlPath}`, 'info', quiet);\n    }\n  } catch (error) {\n    log(`Error setting up GraphQL: ${error.message}`, 'error', quiet);\n  }\n\n  // Fallback for non-GraphQL routes - handle all remaining routes\n  app.use('/', async (req, res) => {\n    try {\n      const url = req.url || '/';\n      const method = req.method || 'GET';\n      const pathname = req.path || url.split('?')[0]; // Extract pathname without query string\n\n      log(`${method} ${url} (pathname: ${pathname})`, 'info', false);\n\n      // Find matching function\n      let matchedFunction = null;\n\n      if(config.functions) {\n        for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n          if(functionConfig.events) {\n            for(const event of functionConfig.events) {\n              if(event.http) {\n                const eventPath = event.http.path || '/';\n                const eventMethod = event.http.method || 'GET';\n\n                // Improved path matching - compare pathname without query string\n                if(eventPath && eventPath === pathname && eventMethod === method) {\n                  matchedFunction = functionName;\n                  break;\n                }\n              }\n            }\n          }\n          if(matchedFunction) {\n            break;\n          }\n        }\n      }\n\n      if(matchedFunction && config.functions[matchedFunction]) {\n        // Resolve handler path relative to output directory\n        const handlerPath = config.functions[matchedFunction].handler;\n        const handler = await loadHandler(handlerPath, outputDir);\n\n        if(handler) {\n          const wrappedHandler = captureConsoleLogs(handler, quiet);\n\n          const event = {\n            body: req.body,\n            headers: req.headers,\n            httpMethod: method,\n            path: url,\n            queryStringParameters: req.query\n          };\n\n          const context = {\n            awsRequestId: 'test-request-id',\n            functionName: matchedFunction,\n            functionVersion: '$LATEST',\n            getRemainingTimeInMillis: () => 30000,\n            invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n            logGroupName: `/aws/lambda/${matchedFunction}`,\n            logStreamName: 'test-log-stream',\n            memoryLimitInMB: '128'\n          };\n\n          try {\n            const result = await wrappedHandler(event, context);\n\n            if(result && typeof result === 'object' && result.statusCode) {\n              res.status(result.statusCode);\n              if(result.headers) {\n                Object.entries(result.headers).forEach(([key, value]) => {\n                  res.setHeader(key, String(value));\n                });\n              }\n              res.send(result.body);\n            } else {\n              res.json(result);\n            }\n          } catch (error) {\n            log(`Handler error: ${error.message}`, 'error', false);\n            res.status(500).json({error: error.message});\n          }\n        } else {\n          res.status(404).json({error: 'Handler not found'});\n        }\n      } else {\n        res.status(404).json({error: 'Function not found'});\n      }\n    } catch (error) {\n      log(`Route handling error: ${error.message}`, 'error', false);\n      res.status(500).json({error: error.message});\n    }\n  });\n\n  return app;\n};\n\nconst createWebSocketServer = (\n  config: ServerlessConfig,\n  outputDir: string,\n  wsPort: number,\n  quiet: boolean,\n  debug: boolean\n) => {\n  const wss = new WebSocketServer({port: wsPort});\n\n  wss.on('connection', async (ws, req) => {\n    log(`WebSocket connection established: ${req.url}`, 'info', false);\n\n    ws.on('message', async (message) => {\n      try {\n        const data = JSON.parse(message.toString());\n\n        // Find matching WebSocket function\n        let matchedFunction = null;\n\n        if(config.functions) {\n          for(const [functionName, functionConfig] of Object.entries(config.functions)) {\n            if(functionConfig.events) {\n              for(const event of functionConfig.events) {\n                if(event.websocket) {\n                  const route = event.websocket.route || '$connect';\n                  if(route === '$default' || route === data.action) {\n                    matchedFunction = functionName;\n                    break;\n                  }\n                }\n              }\n            }\n            if(matchedFunction) {\n              break;\n            }\n          }\n        }\n\n        if(matchedFunction && config.functions[matchedFunction]) {\n          const handler = await loadHandler(config.functions[matchedFunction].handler, outputDir);\n\n          if(handler) {\n            // Wrap handler with console log capture\n            const wrappedHandler = captureConsoleLogs(handler, quiet);\n            const event = {\n              body: data.body || null,\n              requestContext: {\n                apiGateway: {\n                  endpoint: `ws://localhost:${wsPort}`\n                },\n                connectionId: 'test-connection-id',\n                routeKey: data.action || '$default'\n              }\n            };\n\n            const context = {\n              awsRequestId: 'test-request-id',\n              functionName: matchedFunction,\n              functionVersion: '$LATEST',\n              getRemainingTimeInMillis: () => 30000,\n              invokedFunctionArn: `arn:aws:lambda:us-east-1:123456789012:function:${matchedFunction}`,\n              logGroupName: `/aws/lambda/${matchedFunction}`,\n              logStreamName: 'test-log-stream',\n              memoryLimitInMB: '128'\n            };\n\n            const result = await wrappedHandler(event, context);\n\n            // Handle Lambda response format for WebSocket\n            if(result && typeof result === 'object' && result.statusCode) {\n              // This is a Lambda response object, extract the body\n              const body = result.body || '';\n              ws.send(body);\n            } else {\n              // This is a direct response, stringify it\n              ws.send(JSON.stringify(result));\n            }\n          } else {\n            ws.send(JSON.stringify({error: 'Handler not found'}));\n          }\n        } else {\n          ws.send(JSON.stringify({error: 'WebSocket function not found'}));\n        }\n      } catch (error) {\n        log(`WebSocket error: ${error.message}`, 'error', false);\n        ws.send(JSON.stringify({error: error.message}));\n      }\n    });\n\n    ws.on('close', () => {\n      log('WebSocket connection closed', 'info', false);\n    });\n  });\n\n  return wss;\n};\n\nconst loadEnvFile = (envPath: string): Record<string, string> => {\n  const envVars: Record<string, string> = {};\n\n  if(!existsSync(envPath)) {\n    return envVars;\n  }\n\n  try {\n    const envContent = readFileSync(envPath, 'utf8');\n    const lines = envContent.split('\\n');\n\n    for(const line of lines) {\n      const trimmedLine = line.trim();\n\n      // Skip empty lines and comments\n      if(!trimmedLine || trimmedLine.startsWith('#')) {\n        continue;\n      }\n\n      // Parse KEY=value format\n      const equalIndex = trimmedLine.indexOf('=');\n      if(equalIndex > 0) {\n        const key = trimmedLine.substring(0, equalIndex).trim();\n        const value = trimmedLine.substring(equalIndex + 1).trim();\n\n        // Remove quotes if present\n        const cleanValue = value.replace(/^[\"']|[\"']$/g, '');\n\n        if(key) {\n          envVars[key] = cleanValue;\n        }\n      }\n    }\n  } catch (error) {\n    log(`Warning: Could not load .env file at ${envPath}: ${error.message}`, 'warn', false);\n  }\n\n  return envVars;\n};\n\nexport const serverless = async (\n  cmd: ServerlessOptions,\n  callback: ServerlessCallback = () => ({})\n): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    debug = false,\n    host = 'localhost',\n    httpPort = 3000,\n    httpsPort = 3001,\n    quiet = false,\n    remove = false,\n    test = false,\n    usePublicIp,\n    variables,\n    wsPort = 3002\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} starting serverless development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath} = LexConfig.config;\n\n  // Load environment variables from .env files\n  const envPaths = [\n    pathResolve(process.cwd(), '.env'),\n    pathResolve(process.cwd(), '.env.local'),\n    pathResolve(process.cwd(), '.env.development')\n  ];\n\n  let envVars: Record<string, string> = {};\n\n  // Load from .env files in order (later files override earlier ones)\n  for(const envPath of envPaths) {\n    const fileEnvVars = loadEnvFile(envPath);\n    if(Object.keys(fileEnvVars).length > 0) {\n      log(`Loaded environment variables from: ${envPath}`, 'info', quiet);\n    }\n    envVars = {...envVars, ...fileEnvVars};\n  }\n\n  // Start with default NODE_ENV and loaded .env variables\n  let variablesObj: object = {NODE_ENV: 'development', ...envVars};\n\n  // Override with command line variables if provided\n  if(variables) {\n    try {\n      const cliVars = JSON.parse(variables);\n      variablesObj = {...variablesObj, ...cliVars};\n    } catch (_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  // If in test mode, exit early after loading environment variables\n  if(test) {\n    log('Test mode: Environment variables loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n    await removeFiles(outputFullPath || '');\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  // Load serverless configuration\n  let serverlessConfig: ServerlessConfig = {};\n\n  try {\n    const configPath = config || pathResolve(process.cwd(), 'lex.config.mjs');\n    log(`Loading serverless config from: ${configPath}`, 'info', quiet);\n\n    if(existsSync(configPath)) {\n      const configModule = await import(configPath);\n      serverlessConfig = configModule.default?.serverless || configModule.serverless || {};\n      log('Serverless config loaded successfully', 'info', quiet);\n      log(`Loaded functions: ${Object.keys(serverlessConfig.functions || {}).join(', ')}`, 'info', quiet);\n    } else {\n      log(`No serverless config found at ${configPath}, using defaults`, 'warn', quiet);\n    }\n  } catch (error) {\n    log(`Error loading serverless config: ${error.message}`, 'error', quiet);\n    // Don't exit, continue with empty config\n  }\n\n  // Merge config with command line options\n  const finalConfig: ServerlessConfig = {\n    ...serverlessConfig,\n    custom: {\n      'serverless-offline': {\n        cors: serverlessConfig.custom?.['serverless-offline']?.cors !== false,\n        host: serverlessConfig.custom?.['serverless-offline']?.host || host,\n        httpPort: serverlessConfig.custom?.['serverless-offline']?.httpPort || httpPort,\n        httpsPort: serverlessConfig.custom?.['serverless-offline']?.httpsPort || httpsPort,\n        wsPort: serverlessConfig.custom?.['serverless-offline']?.wsPort || wsPort\n      }\n    }\n  };\n\n  const outputDir = outputFullPath || 'lib';\n  log(`Using output directory: ${outputDir}`, 'info', quiet);\n\n  try {\n    spinner.start('Starting serverless development server...');\n\n    const httpPort = finalConfig.custom!['serverless-offline']!.httpPort!;\n    const wsPort = finalConfig.custom!['serverless-offline']!.wsPort!;\n    const host = finalConfig.custom!['serverless-offline']!.host!;\n\n    log(`Creating HTTP server on ${host}:${httpPort}`, 'info', quiet);\n    log(`Creating WebSocket server on port ${wsPort}`, 'info', quiet);\n\n    // Create Express server\n    const expressApp = await createExpressServer(\n      finalConfig,\n      outputDir,\n      httpPort,\n      host,\n      quiet,\n      debug\n    );\n\n    // Create WebSocket server\n    const wsServer = createWebSocketServer(\n      finalConfig,\n      outputDir,\n      wsPort,\n      quiet,\n      debug\n    );\n\n    // Handle server errors\n    wsServer.on('error', (error) => {\n      log(`WebSocket server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start WebSocket server.');\n      callback(1);\n      return;\n    });\n\n    // Start Express server\n    const server = expressApp.listen(httpPort, host, () => {\n      spinner.succeed('Serverless development server started.');\n\n      displayServerStatus(\n        httpPort,\n        finalConfig.custom!['serverless-offline']!.httpsPort!,\n        wsPort,\n        host,\n        quiet\n      );\n\n      fetchPublicIp(usePublicIp).then((publicIp) => {\n        if(publicIp) {\n          displayServerStatus(\n            httpPort,\n            finalConfig.custom!['serverless-offline']!.httpsPort!,\n            wsPort,\n            host,\n            quiet,\n            publicIp\n          );\n        }\n      });\n    });\n\n    // Handle Express server errors\n    server.on('error', (error) => {\n      log(`Express server error: ${error.message}`, 'error', quiet);\n      spinner.fail('Failed to start Express server.');\n      callback(1);\n      return;\n    });\n\n    // Handle graceful shutdown\n    const shutdown = () => {\n      log('\\nShutting down serverless development server...', 'info', quiet);\n      server.close();\n      wsServer.close();\n      callback(0);\n    };\n\n    process.on('SIGINT', shutdown);\n    process.on('SIGTERM', shutdown);\n\n    // Keep the process alive\n    process.stdin.resume();\n\n    log('Serverless development server is running. Press Ctrl+C to stop.', 'info', quiet);\n\n    // Don't call callback here, let the process stay alive\n    return 0;\n  } catch (error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('Failed to start serverless development server.');\n    callback(1);\n    return 1;\n  }\n};"],
  "mappings": "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",
  "names": ["log", "httpPort", "wsPort", "host"]
}

|