@routecraft/cli 0.2.0-canary.8 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,2 @@
1
+ import {logger}from'@routecraft/routecraft';import {resolve}from'path';import {config}from'dotenv';function g(e){let t={quiet:true};if(e){let l=resolve(process.cwd(),e),n=config({path:l,...t});return n.error?logger.info(`Could not load .env file from ${e}: ${n.error.message}`):n.parsed&&logger.debug(`Loaded ${Object.keys(n.parsed).length} environment variables from ${e}`),n}let o=config({path:resolve(process.cwd(),".env"),...t});o.parsed?logger.debug(`Loaded ${Object.keys(o.parsed).length} environment variables from .env`):o.error&&logger.debug("No .env file found");let r=config({path:resolve(process.cwd(),".env.local"),override:true,...t});return r.parsed&&logger.debug(`Loaded ${Object.keys(r.parsed).length} environment variables from .env.local`),r.parsed?r:o.parsed?o:r}function u(e){process.on("SIGINT",async()=>{e.logger.info("Shutting down (SIGINT)..."),await e.stop(),process.exit(0);}),process.on("SIGTERM",async()=>{e.logger.info("Shutting down (SIGTERM)..."),await e.stop(),process.exit(0);}),process.on("exit",()=>{e.logger.info("Cleanup complete");});}export{g as a,u as b};//# sourceMappingURL=chunk-5NEKGUV3.js.map
2
+ //# sourceMappingURL=chunk-5NEKGUV3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/util.ts"],"names":["loadEnvFile","path","dotenvOpts","envPath","resolve","result","loadDotenv","logger","envResult","envLocalResult","registerContextSignalHandlers","context"],"mappings":"mGAUO,SAASA,CAAAA,CAAYC,EAAe,CACzC,IAAMC,EAAa,CAAE,KAAA,CAAO,IAAK,CAAA,CACjC,GAAID,CAAAA,CAAM,CAER,IAAME,CAAAA,CAAUC,QAAQ,OAAA,CAAQ,GAAA,GAAOH,CAAI,CAAA,CACrCI,EAASC,MAAAA,CAAW,CAAE,KAAMH,CAAAA,CAAS,GAAGD,CAAW,CAAC,CAAA,CAE1D,OAAIG,CAAAA,CAAO,KAAA,CACTE,MAAAA,CAAO,IAAA,CACL,CAAA,8BAAA,EAAiCN,CAAI,KAAKI,CAAAA,CAAO,KAAA,CAAM,OAAO,CAAA,CAChE,CAAA,CACSA,EAAO,MAAA,EAChBE,MAAAA,CAAO,MACL,CAAA,OAAA,EAAU,MAAA,CAAO,KAAKF,CAAAA,CAAO,MAAM,EAAE,MAAM,CAAA,4BAAA,EAA+BJ,CAAI,CAAA,CAChF,CAAA,CAGKI,CACT,CAIA,IAAMG,CAAAA,CAAYF,OAAW,CAC3B,IAAA,CAAMF,QAAQ,OAAA,CAAQ,GAAA,GAAO,MAAM,CAAA,CACnC,GAAGF,CACL,CAAC,CAAA,CACGM,EAAU,MAAA,CACZD,MAAAA,CAAO,MACL,CAAA,OAAA,EAAU,MAAA,CAAO,KAAKC,CAAAA,CAAU,MAAM,CAAA,CAAE,MAAM,CAAA,gCAAA,CAChD,CAAA,CACSA,EAAU,KAAA,EACnBD,MAAAA,CAAO,MAAM,oBAAoB,CAAA,CAInC,IAAME,CAAAA,CAAiBH,MAAAA,CAAW,CAChC,IAAA,CAAMF,OAAAA,CAAQ,QAAQ,GAAA,EAAI,CAAG,YAAY,CAAA,CACzC,QAAA,CAAU,KACV,GAAGF,CACL,CAAC,CAAA,CAWD,OAVIO,CAAAA,CAAe,QACjBF,MAAAA,CAAO,KAAA,CACL,UAAU,MAAA,CAAO,IAAA,CAAKE,EAAe,MAAM,CAAA,CAAE,MAAM,CAAA,sCAAA,CACrD,CAAA,CAOEA,CAAAA,CAAe,OACVA,CAAAA,CAELD,CAAAA,CAAU,OACLA,CAAAA,CAEFC,CACT,CAQO,SAASC,CAAAA,CACdC,CAAAA,CACA,CACA,OAAA,CAAQ,EAAA,CAAG,SAAU,SAAY,CAC/BA,EAAQ,MAAA,CAAO,IAAA,CAAK,2BAA2B,CAAA,CAC/C,MAAMA,EAAQ,IAAA,EAAK,CACnB,QAAQ,IAAA,CAAK,CAAC,EAChB,CAAC,CAAA,CACD,QAAQ,EAAA,CAAG,SAAA,CAAW,SAAY,CAChCA,CAAAA,CAAQ,MAAA,CAAO,KAAK,4BAA4B,CAAA,CAChD,MAAMA,CAAAA,CAAQ,IAAA,GACd,OAAA,CAAQ,IAAA,CAAK,CAAC,EAChB,CAAC,CAAA,CACD,QAAQ,EAAA,CAAG,MAAA,CAAQ,IAAM,CACvBA,CAAAA,CAAQ,OAAO,IAAA,CAAK,kBAAkB,EACxC,CAAC,EACH","file":"chunk-5NEKGUV3.js","sourcesContent":["import { logger, CraftContext } from \"@routecraft/routecraft\";\nimport { resolve } from \"node:path\";\nimport { config as loadDotenv } from \"dotenv\";\n\n/**\n * Loads environment variables from .env files\n *\n * @param path Optional path to .env file. If not specified, loads .env and .env.local (if they exist)\n * @returns The parsed dotenv config result\n */\nexport function loadEnvFile(path?: string) {\n const dotenvOpts = { quiet: true };\n if (path) {\n // Explicit path provided - load that file only\n const envPath = resolve(process.cwd(), path);\n const result = loadDotenv({ path: envPath, ...dotenvOpts });\n\n if (result.error) {\n logger.info(\n `Could not load .env file from ${path}: ${result.error.message}`,\n );\n } else if (result.parsed) {\n logger.debug(\n `Loaded ${Object.keys(result.parsed).length} environment variables from ${path}`,\n );\n }\n\n return result;\n }\n\n // No path provided - load .env, then .env.local (with override)\n // Load .env first\n const envResult = loadDotenv({\n path: resolve(process.cwd(), \".env\"),\n ...dotenvOpts,\n });\n if (envResult.parsed) {\n logger.debug(\n `Loaded ${Object.keys(envResult.parsed).length} environment variables from .env`,\n );\n } else if (envResult.error) {\n logger.debug(`No .env file found`);\n }\n\n // Load .env.local next, allowing it to override .env values\n const envLocalResult = loadDotenv({\n path: resolve(process.cwd(), \".env.local\"),\n override: true,\n ...dotenvOpts,\n });\n if (envLocalResult.parsed) {\n logger.debug(\n `Loaded ${Object.keys(envLocalResult.parsed).length} environment variables from .env.local`,\n );\n }\n\n // Return the most successful result:\n // - If .env.local loaded successfully, return it\n // - If .env loaded successfully but .env.local failed (doesn't exist), return .env result\n // - If both failed, return the last error (from .env.local)\n if (envLocalResult.parsed) {\n return envLocalResult;\n }\n if (envResult.parsed) {\n return envResult;\n }\n return envLocalResult;\n}\n\n/**\n * Registers SIGINT, SIGTERM, and exit handlers for a CraftContext instance.\n * Ensures graceful shutdown and logging.\n *\n * @param context The CraftContext instance\n */\nexport function registerContextSignalHandlers(\n context: InstanceType<typeof CraftContext>,\n) {\n process.on(\"SIGINT\", async () => {\n context.logger.info(\"Shutting down (SIGINT)...\");\n await context.stop();\n process.exit(0);\n });\n process.on(\"SIGTERM\", async () => {\n context.logger.info(\"Shutting down (SIGTERM)...\");\n await context.stop();\n process.exit(0);\n });\n process.on(\"exit\", () => {\n context.logger.info(\"Cleanup complete\");\n });\n}\n"]}
package/dist/index.js CHANGED
@@ -1,3 +1,3 @@
1
1
  #!/usr/bin/env node
2
- import {Command}from'commander';import {resolve,extname}from'path';import {logger,ContextBuilder}from'@routecraft/routecraft';import {config}from'dotenv';function f(o){if(o){let s=resolve(process.cwd(),o),e=config({path:s});return e.error?logger.info(`Could not load .env file from ${o}: ${e.error.message}`):e.parsed&&logger.debug(`Loaded ${Object.keys(e.parsed).length} environment variables from ${o}`),e}let r=config({path:resolve(process.cwd(),".env")});r.parsed?logger.debug(`Loaded ${Object.keys(r.parsed).length} environment variables from .env`):r.error&&logger.debug("No .env file found");let n=config({path:resolve(process.cwd(),".env.local"),override:true});return n.parsed&&logger.debug(`Loaded ${Object.keys(n.parsed).length} environment variables from .env.local`),n.parsed?n:r.parsed?r:n}function p(o){process.on("SIGINT",async()=>{o.logger.info("Shutting down (SIGINT)..."),await o.stop(),process.exit(0);}),process.on("SIGTERM",async()=>{o.logger.info("Shutting down (SIGTERM)..."),await o.stop(),process.exit(0);}),process.on("exit",()=>{o.logger.info("Cleanup complete");});}var m=[".mjs",".js",".cjs"];async function g(o){let r=resolve(process.cwd(),o),n=extname(r);if(!m.includes(n))return {success:false,code:1,message:`Error: Only the following file types are supported: ${m.join(", ")}`};if(n===".ts"||n===".tsx")return {success:false,code:1,message:"TypeScript files are not supported by 'craft run'. Compile to .js or use .mjs/.js/.cjs."};try{logger.info(`Loading file: ${r}`);let s=await import(r),e=new ContextBuilder;s.craftConfig&&(logger.info("Found craftConfig export, applying configuration"),e.with(s.craftConfig));let l=w(e,s.default);if(!l.success)return l;let d=e.build();return p(d),await d.start(),{success:!0}}catch(s){return s instanceof Error?(logger.error(`Failed to run ${r}: ${s.message}`),{success:false,code:1,message:s.message}):(logger.error(`Failed to run ${r}: Unknown error occurred`),{success:false,code:1,message:"Unknown error"})}}function w(o,r){let n=e=>typeof e=="object"&&e!==null&&typeof e.build=="function",s=e=>typeof e=="object"&&e!==null&&"id"in e&&typeof e.id=="string"&&"source"in e&&"steps"in e&&"consumer"in e;return r?n(r)?(o.routes(r),logger.info("Loaded single RouteBuilder from default export"),{success:true}):s(r)?(o.routes(r),logger.info("Loaded single route from default export"),{success:true}):Array.isArray(r)?r.every(e=>n(e)||s(e))?(r.forEach(e=>o.routes(e)),logger.info(`Loaded ${r.length} routes from default export array`),{success:true}):(logger.error("All items in default export array must be RouteDefinition or RouteBuilder"),{success:false,code:1,message:"Invalid items in default export array"}):(logger.error("Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those."),{success:false,code:1,message:"Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those."}):(logger.error("No default export found. Expected routes as default export."),{success:false,code:1,message:"No default export found"})}var a=new Command;a.name("craft").description("A modern routing framework for TypeScript").version("0.2.0-canary.8").showSuggestionAfterError().showHelpAfterError().exitOverride(o=>{o.code==="commander.unknownCommand"&&process.exit(0);});process.argv.length<=2&&a.help({error:false});a.command("run").description("Run routes from a single TypeScript/JavaScript file").argument("<file>","Path to a file containing routes").option("--env <path>","Load environment variables from a .env file (default: .env)").action(async(o,r)=>{r.env!==void 0?f(r.env):f();let n=await g(o);n.success||(n.message&&console.error(n.message),process.exit(n.code??1));});a.parse();//# sourceMappingURL=index.js.map
2
+ var[n,a]=process.version.slice(1).split(".").map(Number);n>18||n===18&&a>=19||(console.error(`[routecraft] Node.js ${process.version} is not supported. Routecraft requires Node.js 18.19.0 or later (e.g. 20 or 22). Please upgrade Node or configure your MCP client to use a newer Node.`),process.exit(1));process.env.LOG_LEVEL===void 0&&(process.env.LOG_LEVEL="warn");process.env.CRAFT_LOG_LEVEL===void 0&&(process.env.CRAFT_LOG_LEVEL="warn");for(let o=0;o<process.argv.length;o++){let r=process.argv[o];if(r==="--log-file"&&process.argv[o+1]){let e=process.argv[o+1];process.env.LOG_FILE=e,process.env.CRAFT_LOG_FILE=e;}else if(r.startsWith("--log-file=")){let e=r.slice(11);process.env.LOG_FILE=e,process.env.CRAFT_LOG_FILE=e;}if(r==="--log-level"&&process.argv[o+1]){let e=process.argv[o+1];process.env.LOG_LEVEL=e,process.env.CRAFT_LOG_LEVEL=e;}else if(r.startsWith("--log-level=")){let e=r.slice(12);process.env.LOG_LEVEL=e,process.env.CRAFT_LOG_LEVEL=e;}}var{Command:l}=await import('commander'),{runCommand:c}=await import('./run-QPVX635B.js'),{loadEnvFile:t}=await import('./util-Q5GDRTSI.js'),s=new l;s.name("craft").description("A modern routing framework for TypeScript").version("0.2.0").showSuggestionAfterError().showHelpAfterError().exitOverride(o=>{o.code==="commander.unknownCommand"&&process.exit(0);});process.argv.length<=2&&s.help({error:false});s.command("run").description("Run routes from a single TypeScript/JavaScript file").argument("<file>","Path to a file containing routes").option("--env <path>","Load environment variables from a .env file (default: .env)").option("--log-file <path>","Write logs to a file (keeps stdout clear for MCP stdio)").option("--log-level <level>","Log level (e.g. info, warn, error, silent to disable)","warn").action(async(o,r)=>{r.env!==void 0?t(r.env):t();let e=await c(o);if(!e.success){e.message&&console.error(e.message);let i=e.code??1;setImmediate(()=>process.exit(i));return}});s.parse();//# sourceMappingURL=index.js.map
3
3
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/util.ts","../src/run.ts","../src/index.ts"],"names":["loadEnvFile","path","envPath","resolve","result","loadDotenv","logger","envResult","envLocalResult","registerContextSignalHandlers","context","SUPPORTED_EXTENSIONS","runCommand","filePath","absFilePath","ext","extname","module","contextBuilder","ContextBuilder","configured","configureRoutes","error","defaultExport","isRouteBuilder","obj","isRouteDefinition","item","routeOrBuilder","program","Command","err","options"],"mappings":"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","file":"index.js","sourcesContent":["import { logger, CraftContext } from \"@routecraft/routecraft\";\nimport { resolve } from \"node:path\";\nimport { config as loadDotenv } from \"dotenv\";\n\n/**\n * Loads environment variables from .env files\n *\n * @param path Optional path to .env file. If not specified, loads .env and .env.local (if they exist)\n * @returns The parsed dotenv config result\n */\nexport function loadEnvFile(path?: string) {\n if (path) {\n // Explicit path provided - load that file only\n const envPath = resolve(process.cwd(), path);\n const result = loadDotenv({ path: envPath });\n\n if (result.error) {\n logger.info(\n `Could not load .env file from ${path}: ${result.error.message}`,\n );\n } else if (result.parsed) {\n logger.debug(\n `Loaded ${Object.keys(result.parsed).length} environment variables from ${path}`,\n );\n }\n\n return result;\n }\n\n // No path provided - load .env, then .env.local (with override)\n // Load .env first\n const envResult = loadDotenv({ path: resolve(process.cwd(), \".env\") });\n if (envResult.parsed) {\n logger.debug(\n `Loaded ${Object.keys(envResult.parsed).length} environment variables from .env`,\n );\n } else if (envResult.error) {\n logger.debug(`No .env file found`);\n }\n\n // Load .env.local next, allowing it to override .env values\n const envLocalResult = loadDotenv({\n path: resolve(process.cwd(), \".env.local\"),\n override: true,\n });\n if (envLocalResult.parsed) {\n logger.debug(\n `Loaded ${Object.keys(envLocalResult.parsed).length} environment variables from .env.local`,\n );\n }\n\n // Return the most successful result:\n // - If .env.local loaded successfully, return it\n // - If .env loaded successfully but .env.local failed (doesn't exist), return .env result\n // - If both failed, return the last error (from .env.local)\n if (envLocalResult.parsed) {\n return envLocalResult;\n }\n if (envResult.parsed) {\n return envResult;\n }\n return envLocalResult;\n}\n\n/**\n * Registers SIGINT, SIGTERM, and exit handlers for a CraftContext instance.\n * Ensures graceful shutdown and logging.\n *\n * @param context The CraftContext instance\n */\nexport function registerContextSignalHandlers(\n context: InstanceType<typeof CraftContext>,\n) {\n process.on(\"SIGINT\", async () => {\n context.logger.info(\"Shutting down (SIGINT)...\");\n await context.stop();\n process.exit(0);\n });\n process.on(\"SIGTERM\", async () => {\n context.logger.info(\"Shutting down (SIGTERM)...\");\n await context.stop();\n process.exit(0);\n });\n process.on(\"exit\", () => {\n context.logger.info(\"Cleanup complete\");\n });\n}\n","import { resolve, extname } from \"node:path\";\nimport {\n ContextBuilder,\n type RouteDefinition,\n type CraftConfig,\n logger,\n RouteBuilder,\n} from \"@routecraft/routecraft\";\nimport { registerContextSignalHandlers } from \"./util\";\n\nconst SUPPORTED_EXTENSIONS = [\".mjs\", \".js\", \".cjs\"] as const;\n\ntype RunResult =\n | { success: true }\n | { success: false; code?: number; message: string };\n\nexport async function runCommand(filePath: string): Promise<RunResult> {\n const absFilePath = resolve(process.cwd(), filePath);\n const ext = extname(absFilePath);\n\n // Validate file extension\n if (\n !SUPPORTED_EXTENSIONS.includes(ext as (typeof SUPPORTED_EXTENSIONS)[number])\n ) {\n return {\n success: false,\n code: 1,\n message: `Error: Only the following file types are supported: ${SUPPORTED_EXTENSIONS.join(\", \")}`,\n };\n }\n\n // Reject TypeScript files explicitly\n if (ext === \".ts\" || ext === \".tsx\") {\n return {\n success: false,\n code: 1,\n message:\n \"TypeScript files are not supported by 'craft run'. Compile to .js or use .mjs/.js/.cjs.\",\n };\n }\n\n try {\n logger.info(`Loading file: ${absFilePath}`);\n\n // Load the module with both default and named exports\n const module = await import(absFilePath);\n\n // Create context builder\n const contextBuilder = new ContextBuilder();\n\n // Check for optional craftConfig named export\n if (module.craftConfig) {\n logger.info(\"Found craftConfig export, applying configuration\");\n contextBuilder.with(module.craftConfig as CraftConfig);\n }\n\n // Handle routes from the default export\n const configured = configureRoutes(contextBuilder, module.default);\n if (!configured.success) {\n return configured;\n }\n\n // Build and start the context\n const context = contextBuilder.build();\n registerContextSignalHandlers(context);\n await context.start();\n\n return { success: true };\n } catch (error: unknown) {\n if (error instanceof Error) {\n logger.error(`Failed to run ${absFilePath}: ${error.message}`);\n return { success: false, code: 1, message: error.message };\n }\n logger.error(`Failed to run ${absFilePath}: Unknown error occurred`);\n return { success: false, code: 1, message: \"Unknown error\" };\n }\n}\n\nfunction configureRoutes(\n contextBuilder: InstanceType<typeof ContextBuilder>,\n defaultExport: unknown,\n): RunResult {\n // Type guards\n const isRouteBuilder = (\n obj: unknown,\n ): obj is InstanceType<typeof RouteBuilder> =>\n typeof obj === \"object\" &&\n obj !== null &&\n typeof (obj as { build?: unknown }).build === \"function\";\n\n const isRouteDefinition = (obj: unknown): obj is RouteDefinition =>\n typeof obj === \"object\" &&\n obj !== null &&\n \"id\" in obj &&\n typeof obj.id === \"string\" && // Ensure id is a string, not a method\n \"source\" in obj &&\n \"steps\" in obj &&\n \"consumer\" in obj;\n\n if (!defaultExport) {\n logger.error(\"No default export found. Expected routes as default export.\");\n return { success: false, code: 1, message: \"No default export found\" };\n }\n\n // Handle single RouteBuilder or RouteDefinition\n // Check RouteBuilder first since it also has an 'id' property (as a method)\n if (isRouteBuilder(defaultExport)) {\n contextBuilder.routes(defaultExport);\n logger.info(\"Loaded single RouteBuilder from default export\");\n return { success: true };\n }\n\n if (isRouteDefinition(defaultExport)) {\n contextBuilder.routes(defaultExport);\n logger.info(\"Loaded single route from default export\");\n return { success: true };\n }\n\n // Handle array of routes\n if (Array.isArray(defaultExport)) {\n // Check each item, prioritizing RouteBuilder check\n if (\n !defaultExport.every(\n (item) => isRouteBuilder(item) || isRouteDefinition(item),\n )\n ) {\n logger.error(\n \"All items in default export array must be RouteDefinition or RouteBuilder\",\n );\n return {\n success: false,\n code: 1,\n message: \"Invalid items in default export array\",\n };\n }\n\n defaultExport.forEach((routeOrBuilder) =>\n contextBuilder.routes(\n routeOrBuilder as RouteDefinition | InstanceType<typeof RouteBuilder>,\n ),\n );\n logger.info(\n `Loaded ${defaultExport.length} routes from default export array`,\n );\n return { success: true };\n }\n\n // Invalid default export\n logger.error(\n \"Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those.\",\n );\n return {\n success: false,\n code: 1,\n message:\n \"Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those.\",\n };\n}\n","#!/usr/bin/env node\n\n/**\n * Routecraft CLI Module\n *\n * This module provides the command-line interface for Routecraft.\n */\nimport { Command } from \"commander\";\nimport { runCommand } from \"./run.ts\";\nimport { loadEnvFile } from \"./util.ts\";\n\n/**\n * The main command program for the Routecraft CLI.\n * Built using the commander.js library.\n */\nconst program = new Command();\n\nprogram\n .name(\"craft\")\n .description(\"A modern routing framework for TypeScript\")\n .version(\"0.2.0-canary.8\")\n .showSuggestionAfterError()\n .showHelpAfterError()\n .exitOverride((err) => {\n if (err.code === \"commander.unknownCommand\") {\n process.exit(0);\n }\n });\n\n// Show help by default if no arguments provided\nif (process.argv.length <= 2) {\n program.help({ error: false });\n}\n\n/**\n * The 'run' command executes routes from a single file.\n *\n * Example:\n * craft run ./my-routes.ts\n */\nprogram\n .command(\"run\")\n .description(\"Run routes from a single TypeScript/JavaScript file\")\n .argument(\"<file>\", \"Path to a file containing routes\")\n .option(\n \"--env <path>\",\n \"Load environment variables from a .env file (default: .env)\",\n )\n .action(async (filePath, options) => {\n // Load environment variables if specified or use default .env\n if (options.env !== undefined) {\n loadEnvFile(options.env);\n } else {\n loadEnvFile();\n }\n\n const result = await runCommand(filePath);\n if (!result.success) {\n if (result.message) {\n // eslint-disable-next-line no-console\n console.error(result.message);\n }\n process.exit(result.code ?? 1);\n }\n });\n\n// Parse the command line arguments and execute the appropriate command\nprogram.parse();\n"]}
1
+ {"version":3,"sources":["../src/index.ts"],"names":["major","minor","i","arg","path","level","Command","runCommand","loadEnvFile","program","err","filePath","options","result","code"],"mappings":"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","file":"index.js","sourcesContent":["#!/usr/bin/env node\n\n/**\n * Routecraft CLI — single entry point.\n *\n * 1. Check Node version (Pino 10 needs Node 18.19+)\n * 2. Set LOG_FILE / LOG_LEVEL from argv before any import touches pino\n * 3. Dynamically import the rest so env is ready when the logger initialises\n */\n\n// ── 1. Node version gate ────────────────────────────────────────────\nconst [major, minor] = process.version.slice(1).split(\".\").map(Number) as [\n number,\n number,\n];\n\nif (!(major > 18 || (major === 18 && minor >= 19))) {\n // eslint-disable-next-line no-console\n console.error(\n `[routecraft] Node.js ${process.version} is not supported. ` +\n `Routecraft requires Node.js 18.19.0 or later (e.g. 20 or 22). ` +\n `Please upgrade Node or configure your MCP client to use a newer Node.`,\n );\n process.exit(1);\n}\n\n// ── 2. Early argv scan for log options (before loadEnvFile/runCommand) ─\n// Default level so logger sees \"warn\" if nothing else is set\nif (process.env[\"LOG_LEVEL\"] === undefined) {\n process.env[\"LOG_LEVEL\"] = \"warn\";\n}\nif (process.env[\"CRAFT_LOG_LEVEL\"] === undefined) {\n process.env[\"CRAFT_LOG_LEVEL\"] = \"warn\";\n}\nfor (let i = 0; i < process.argv.length; i++) {\n const arg = process.argv[i];\n if (arg === \"--log-file\" && process.argv[i + 1]) {\n const path = process.argv[i + 1];\n process.env[\"LOG_FILE\"] = path;\n process.env[\"CRAFT_LOG_FILE\"] = path;\n } else if (arg.startsWith(\"--log-file=\")) {\n const path = arg.slice(\"--log-file=\".length);\n process.env[\"LOG_FILE\"] = path;\n process.env[\"CRAFT_LOG_FILE\"] = path;\n }\n if (arg === \"--log-level\" && process.argv[i + 1]) {\n const level = process.argv[i + 1];\n process.env[\"LOG_LEVEL\"] = level;\n process.env[\"CRAFT_LOG_LEVEL\"] = level;\n } else if (arg.startsWith(\"--log-level=\")) {\n const level = arg.slice(\"--log-level=\".length);\n process.env[\"LOG_LEVEL\"] = level;\n process.env[\"CRAFT_LOG_LEVEL\"] = level;\n }\n}\n\n// ── 3. Dynamic imports (pino is loaded here, sees env vars above) ───\nconst { Command } = await import(\"commander\");\nconst { runCommand } = await import(\"./run.js\");\nconst { loadEnvFile } = await import(\"./util.js\");\n\n// ── 4. CLI definition ──────────────────────────────────────────────\nconst program = new Command();\n\nprogram\n .name(\"craft\")\n .description(\"A modern routing framework for TypeScript\")\n .version(\"0.2.0\")\n .showSuggestionAfterError()\n .showHelpAfterError()\n .exitOverride((err) => {\n if (err.code === \"commander.unknownCommand\") {\n process.exit(0);\n }\n });\n\n// Show help by default if no arguments provided\nif (process.argv.length <= 2) {\n program.help({ error: false });\n}\n\n/**\n * The 'run' command executes routes from a single file.\n *\n * Example:\n * craft run ./my-routes.ts\n */\nprogram\n .command(\"run\")\n .description(\"Run routes from a single TypeScript/JavaScript file\")\n .argument(\"<file>\", \"Path to a file containing routes\")\n .option(\n \"--env <path>\",\n \"Load environment variables from a .env file (default: .env)\",\n )\n .option(\n \"--log-file <path>\",\n \"Write logs to a file (keeps stdout clear for MCP stdio)\",\n )\n .option(\n \"--log-level <level>\",\n \"Log level (e.g. info, warn, error, silent to disable)\",\n \"warn\",\n )\n .action(async (filePath, options) => {\n // Load environment variables if specified or use default .env\n if (options.env !== undefined) {\n loadEnvFile(options.env);\n } else {\n loadEnvFile();\n }\n\n const result = await runCommand(filePath);\n if (!result.success) {\n if (result.message) {\n // eslint-disable-next-line no-console\n console.error(result.message);\n }\n // Defer exit so pino/sonic-boom can finish initializing and avoid \"sonic boom is not ready yet\"\n const code = result.code ?? 1;\n setImmediate(() => process.exit(code));\n return;\n }\n });\n\n// Parse the command line arguments and execute the appropriate command\nprogram.parse();\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-5NEKGUV3.js';import {resolve,extname}from'path';import {configureLogger,logger,ContextBuilder,isRouteBuilder,isRouteDefinition}from'@routecraft/routecraft';var g=[".mjs",".js",".cjs"];async function E(n){let e=resolve(process.cwd(),n),o=extname(e);if(o===".ts"||o===".tsx")return {success:false,code:1,message:"TypeScript files are not supported by 'craft run'. Compile to .js or use .mjs/.js/.cjs."};if(!g.includes(o))return {success:false,code:1,message:`Error: Only the following file types are supported: ${g.join(", ")}`};try{let s=await import(e),t=s.craftConfig,u=process.env.LOG_FILE??process.env.CRAFT_LOG_FILE??t?.log?.file,m={level:process.env.LOG_LEVEL??process.env.CRAFT_LOG_LEVEL??t?.log?.level??"warn",...u!==void 0&&{logFile:u},...t?.log?.redact!==void 0&&{redact:t.log.redact}};configureLogger(m),logger.info(`Loading file: ${e}`);let i=new ContextBuilder;t&&(logger.info("Found craftConfig export, applying configuration"),i.with(t));let a=w(i,s.default);if(!a.success)return a;let c=await i.build();return b(c),await c.start(),{success:!0}}catch(s){return s instanceof Error?(logger.error(`Failed to run ${e}: ${s.message}`),{success:false,code:1,message:s.message}):(logger.error(`Failed to run ${e}: Unknown error occurred`),{success:false,code:1,message:"Unknown error"})}}function w(n,e){return e?isRouteBuilder(e)?(n.routes(e),logger.info("Loaded single RouteBuilder from default export"),{success:true}):isRouteDefinition(e)?(n.routes(e),logger.info("Loaded single route from default export"),{success:true}):Array.isArray(e)?e.every(o=>isRouteBuilder(o)||isRouteDefinition(o))?(e.forEach(o=>n.routes(o)),logger.info(`Loaded ${e.length} routes from default export array`),{success:true}):(logger.error("All items in default export array must be RouteDefinition or RouteBuilder"),{success:false,code:1,message:"Invalid items in default export array"}):(logger.error("Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those."),{success:false,code:1,message:"Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those."}):(logger.error("No default export found. Expected routes as default export."),{success:false,code:1,message:"No default export found"})}export{E as runCommand};//# sourceMappingURL=run-QPVX635B.js.map
2
+ //# sourceMappingURL=run-QPVX635B.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/run.ts"],"names":["SUPPORTED_EXTENSIONS","runCommand","filePath","absFilePath","resolve","ext","extname","module","craftConfig","logFile","mergedLog","configureLogger","logger","contextBuilder","ContextBuilder","configured","configureRoutes","context","registerContextSignalHandlers","error","defaultExport","isRouteBuilder","isRouteDefinition","item","routeOrBuilder"],"mappings":"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","file":"run-QPVX635B.js","sourcesContent":["import { resolve, extname } from \"node:path\";\nimport {\n ContextBuilder,\n type CraftConfig,\n configureLogger,\n isRouteBuilder,\n isRouteDefinition,\n logger,\n type RouteBuilder,\n type RouteDefinition,\n} from \"@routecraft/routecraft\";\nimport { registerContextSignalHandlers } from \"./util\";\n\nconst SUPPORTED_EXTENSIONS = [\".mjs\", \".js\", \".cjs\"] as const;\n\ntype RunResult =\n | { success: true }\n | { success: false; code?: number; message: string };\n\nexport async function runCommand(filePath: string): Promise<RunResult> {\n const absFilePath = resolve(process.cwd(), filePath);\n const ext = extname(absFilePath);\n\n // Reject TypeScript files explicitly (before generic extension check)\n if (ext === \".ts\" || ext === \".tsx\") {\n return {\n success: false,\n code: 1,\n message:\n \"TypeScript files are not supported by 'craft run'. Compile to .js or use .mjs/.js/.cjs.\",\n };\n }\n\n // Validate file extension\n if (\n !SUPPORTED_EXTENSIONS.includes(ext as (typeof SUPPORTED_EXTENSIONS)[number])\n ) {\n return {\n success: false,\n code: 1,\n message: `Error: Only the following file types are supported: ${SUPPORTED_EXTENSIONS.join(\", \")}`,\n };\n }\n\n try {\n // Load the module first so we can read craftConfig and set up logging before any logger use.\n const module = await import(absFilePath);\n const craftConfig = module.craftConfig as CraftConfig | undefined;\n\n // Merge log options: CLI env over craft config over defaults, then configure once.\n const logFile =\n process.env[\"LOG_FILE\"] ??\n process.env[\"CRAFT_LOG_FILE\"] ??\n craftConfig?.log?.file;\n const mergedLog: Parameters<typeof configureLogger>[0] = {\n level:\n process.env[\"LOG_LEVEL\"] ??\n process.env[\"CRAFT_LOG_LEVEL\"] ??\n craftConfig?.log?.level ??\n \"warn\",\n ...(logFile !== undefined && { logFile }),\n ...(craftConfig?.log?.redact !== undefined && {\n redact: craftConfig.log.redact,\n }),\n };\n configureLogger(mergedLog);\n\n logger.info(`Loading file: ${absFilePath}`);\n\n // Create context builder\n const contextBuilder = new ContextBuilder();\n\n // Apply craftConfig (routes, plugins, etc.); log was already applied above.\n if (craftConfig) {\n logger.info(\"Found craftConfig export, applying configuration\");\n contextBuilder.with(craftConfig);\n }\n\n // Handle routes from the default export\n const configured = configureRoutes(contextBuilder, module.default);\n if (!configured.success) {\n return configured;\n }\n\n // Build and start the context\n const context = await contextBuilder.build();\n registerContextSignalHandlers(context);\n await context.start();\n\n return { success: true };\n } catch (error: unknown) {\n if (error instanceof Error) {\n logger.error(`Failed to run ${absFilePath}: ${error.message}`);\n return { success: false, code: 1, message: error.message };\n }\n logger.error(`Failed to run ${absFilePath}: Unknown error occurred`);\n return { success: false, code: 1, message: \"Unknown error\" };\n }\n}\n\nfunction configureRoutes(\n contextBuilder: InstanceType<typeof ContextBuilder>,\n defaultExport: unknown,\n): RunResult {\n if (!defaultExport) {\n logger.error(\"No default export found. Expected routes as default export.\");\n return { success: false, code: 1, message: \"No default export found\" };\n }\n\n // Handle single RouteBuilder or RouteDefinition (brand-based guards for cross-instance)\n if (isRouteBuilder(defaultExport)) {\n contextBuilder.routes(defaultExport as RouteBuilder<unknown>);\n logger.info(\"Loaded single RouteBuilder from default export\");\n return { success: true };\n }\n\n if (isRouteDefinition(defaultExport)) {\n contextBuilder.routes(defaultExport as RouteDefinition);\n logger.info(\"Loaded single route from default export\");\n return { success: true };\n }\n\n // Handle array of routes\n if (Array.isArray(defaultExport)) {\n // Check each item, prioritizing RouteBuilder check\n if (\n !defaultExport.every(\n (item) => isRouteBuilder(item) || isRouteDefinition(item),\n )\n ) {\n logger.error(\n \"All items in default export array must be RouteDefinition or RouteBuilder\",\n );\n return {\n success: false,\n code: 1,\n message: \"Invalid items in default export array\",\n };\n }\n\n defaultExport.forEach((routeOrBuilder) =>\n contextBuilder.routes(\n routeOrBuilder as RouteDefinition | RouteBuilder<unknown>,\n ),\n );\n logger.info(\n `Loaded ${defaultExport.length} routes from default export array`,\n );\n return { success: true };\n }\n\n // Invalid default export\n logger.error(\n \"Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those.\",\n );\n return {\n success: false,\n code: 1,\n message:\n \"Invalid default export. Expected: RouteDefinition, RouteBuilder, or array of those.\",\n };\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export{a as loadEnvFile,b as registerContextSignalHandlers}from'./chunk-5NEKGUV3.js';//# sourceMappingURL=util-Q5GDRTSI.js.map
2
+ //# sourceMappingURL=util-Q5GDRTSI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"util-Q5GDRTSI.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@routecraft/cli",
3
- "version": "0.2.0-canary.8",
3
+ "version": "0.2.0",
4
4
  "description": "CLI for running RouteCraft routes",
5
5
  "private": false,
6
6
  "type": "module",
@@ -22,9 +22,9 @@
22
22
  "prepublishOnly": "pnpm run build"
23
23
  },
24
24
  "dependencies": {
25
- "@routecraft/routecraft": "^0.2.0-canary.8",
25
+ "@routecraft/routecraft": "workspace:^0.2.0",
26
26
  "commander": "^14.0.3",
27
- "dotenv": "^17.2.3"
27
+ "dotenv": "^17.3.1"
28
28
  },
29
29
  "publishConfig": {
30
30
  "access": "public"
@@ -33,6 +33,9 @@
33
33
  "bin": {
34
34
  "craft": "./dist/index.js"
35
35
  },
36
+ "engines": {
37
+ "node": ">=18.19.0"
38
+ },
36
39
  "keywords": [
37
40
  "routecraft",
38
41
  "cli",