@routecraft/cli 0.3.0-canary.2 → 0.3.0-canary.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/dist/chunk-MEHNJKKK.js +2 -0
- package/dist/chunk-MEHNJKKK.js.map +1 -0
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/{run-7VWZQA3U.js → run-IJNIE5VV.js} +2 -2
- package/dist/{run-7VWZQA3U.js.map → run-IJNIE5VV.js.map} +1 -1
- package/dist/util-5TR67ZZL.js +2 -0
- package/dist/{util-Q5GDRTSI.js.map → util-5TR67ZZL.js.map} +1 -1
- package/package.json +4 -3
- package/dist/chunk-5NEKGUV3.js +0 -2
- package/dist/chunk-5NEKGUV3.js.map +0 -1
- package/dist/util-Q5GDRTSI.js +0 -2
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {logger}from'@routecraft/routecraft';import {resolve}from'path';import {config}from'dotenv';function c(e){let s={quiet:true};if(e){let l=resolve(process.cwd(),e),n=config({path:l,...s});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"),...s});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,...s});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(),e.logger.info("Cleanup complete");}),process.on("SIGTERM",async()=>{e.logger.info("Shutting down (SIGTERM)..."),await e.stop(),e.logger.info("Cleanup complete");});}export{c as a,u as b};//# sourceMappingURL=chunk-MEHNJKKK.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-MEHNJKKK.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,EAAM,CAER,IAAME,EAAUC,OAAAA,CAAQ,OAAA,CAAQ,KAAI,CAAGH,CAAI,EACrCI,CAAAA,CAASC,MAAAA,CAAW,CAAE,IAAA,CAAMH,CAAAA,CAAS,GAAGD,CAAW,CAAC,EAE1D,OAAIG,CAAAA,CAAO,MACTE,MAAAA,CAAO,IAAA,CACL,iCAAiCN,CAAI,CAAA,EAAA,EAAKI,EAAO,KAAA,CAAM,OAAO,EAChE,CAAA,CACSA,CAAAA,CAAO,QAChBE,MAAAA,CAAO,KAAA,CACL,UAAU,MAAA,CAAO,IAAA,CAAKF,EAAO,MAAM,CAAA,CAAE,MAAM,CAAA,4BAAA,EAA+BJ,CAAI,EAChF,CAAA,CAGKI,CACT,CAIA,IAAMG,CAAAA,CAAYF,OAAW,CAC3B,IAAA,CAAMF,QAAQ,OAAA,CAAQ,GAAA,GAAO,MAAM,CAAA,CACnC,GAAGF,CACL,CAAC,EACGM,CAAAA,CAAU,MAAA,CACZD,OAAO,KAAA,CACL,CAAA,OAAA,EAAU,OAAO,IAAA,CAAKC,CAAAA,CAAU,MAAM,CAAA,CAAE,MAAM,kCAChD,CAAA,CACSA,CAAAA,CAAU,OACnBD,MAAAA,CAAO,KAAA,CAAM,oBAAoB,CAAA,CAInC,IAAME,EAAiBH,MAAAA,CAAW,CAChC,KAAMF,OAAAA,CAAQ,OAAA,CAAQ,KAAI,CAAG,YAAY,EACzC,QAAA,CAAU,IAAA,CACV,GAAGF,CACL,CAAC,EAWD,OAVIO,CAAAA,CAAe,QACjBF,MAAAA,CAAO,KAAA,CACL,UAAU,MAAA,CAAO,IAAA,CAAKE,EAAe,MAAM,CAAA,CAAE,MAAM,CAAA,sCAAA,CACrD,CAAA,CAOEA,EAAe,MAAA,CACVA,CAAAA,CAELD,EAAU,MAAA,CACLA,CAAAA,CAEFC,CACT,CAQO,SAASC,EACdC,CAAAA,CACA,CACA,QAAQ,EAAA,CAAG,QAAA,CAAU,SAAY,CAC/BA,CAAAA,CAAQ,OAAO,IAAA,CAAK,2BAA2B,EAC/C,MAAMA,CAAAA,CAAQ,MAAK,CACnBA,CAAAA,CAAQ,OAAO,IAAA,CAAK,kBAAkB,EACxC,CAAC,CAAA,CACD,QAAQ,EAAA,CAAG,SAAA,CAAW,SAAY,CAChCA,CAAAA,CAAQ,OAAO,IAAA,CAAK,4BAA4B,EAChD,MAAMA,CAAAA,CAAQ,MAAK,CACnBA,CAAAA,CAAQ,OAAO,IAAA,CAAK,kBAAkB,EACxC,CAAC,EACH","file":"chunk-MEHNJKKK.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 and SIGTERM 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 context.logger.info(\"Cleanup complete\");\n });\n process.on(\"SIGTERM\", async () => {\n context.logger.info(\"Shutting down (SIGTERM)...\");\n await context.stop();\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
|
-
var[t,c]=process.version.slice(1).split(".").map(Number);t>18||t===18&&c>=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));var{Command:p}=await import('commander'),o=new p;o.name("craft").description("A modern routing framework for TypeScript").version("0.3.0-canary.
|
|
2
|
+
var[t,c]=process.version.slice(1).split(".").map(Number);t>18||t===18&&c>=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));var{Command:p}=await import('commander'),o=new p;o.name("craft").description("A modern routing framework for TypeScript").version("0.3.0-canary.4").option("--log-level <level>","Log level (e.g. info, warn, error, silent to disable)").option("--log-file <path>","Write logs to a file (keeps stdout clear for MCP stdio)").showSuggestionAfterError().showHelpAfterError().exitOverride(n=>{n.code==="commander.unknownCommand"&&process.exit(0);});process.argv.length<=2&&o.help({error:false});o.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(n,s)=>{let e=o.opts();e.logLevel!==void 0&&(process.env.LOG_LEVEL=e.logLevel,process.env.CRAFT_LOG_LEVEL=e.logLevel),e.logFile!==void 0&&(process.env.LOG_FILE=e.logFile,process.env.CRAFT_LOG_FILE=e.logFile);let{loadEnvFile:i}=await import('./util-5TR67ZZL.js');s.env!==void 0?i(s.env):i();let{runCommand:a}=await import('./run-IJNIE5VV.js'),r=await a(n);if(!r.success){r.message&&console.error(r.message);let l=r.code??1;setImmediate(()=>process.exit(l));return}});o.parse();//# sourceMappingURL=index.js.map
|
|
3
3
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"names":["major","minor","Command","program","err","filePath","options","globalOpts","loadEnvFile","runCommand","result","code"],"mappings":";AAUA,GAAM,CAACA,EAAOC,CAAK,CAAA,CAAI,QAAQ,OAAA,CAAQ,KAAA,CAAM,CAAC,CAAA,CAAE,KAAA,CAAM,GAAG,CAAA,CAAE,GAAA,CAAI,MAAM,CAAA,CAK/DD,CAAAA,CAAQ,IAAOA,CAAAA,GAAU,EAAA,EAAMC,CAAAA,EAAS,EAAA,GAE5C,OAAA,CAAQ,KAAA,CACN,wBAAwB,OAAA,CAAQ,OAAO,wJAGzC,CAAA,CACA,OAAA,CAAQ,KAAK,CAAC,CAAA,CAAA,CAIhB,GAAM,CAAE,OAAA,CAAAC,CAAQ,EAAI,MAAM,OAAO,WAAW,CAAA,CACtCC,CAAAA,CAAU,IAAID,CAAAA,CAEpBC,CAAAA,CACG,IAAA,CAAK,OAAO,CAAA,CACZ,WAAA,CAAY,2CAA2C,CAAA,CACvD,OAAA,CAAQ,gBAAgB,CAAA,CACxB,MAAA,CACC,sBACA,uDACF,CAAA,CACC,OACC,mBAAA,CACA,yDACF,EACC,wBAAA,EAAyB,CACzB,oBAAmB,CACnB,YAAA,CAAcC,GAAQ,CACjBA,CAAAA,CAAI,IAAA,GAAS,0BAAA,EACf,OAAA,CAAQ,IAAA,CAAK,CAAC,EAElB,CAAC,EAGC,OAAA,CAAQ,IAAA,CAAK,QAAU,CAAA,EACzBD,CAAAA,CAAQ,IAAA,CAAK,CAAE,KAAA,CAAO,KAAM,CAAC,CAAA,CAS/BA,CAAAA,CACG,QAAQ,KAAK,CAAA,CACb,YAAY,qDAAqD,CAAA,CACjE,QAAA,CAAS,QAAA,CAAU,kCAAkC,CAAA,CACrD,OACC,cAAA,CACA,6DACF,EACC,MAAA,CAAO,MAAOE,EAAUC,CAAAA,GAAY,CAEnC,IAAMC,CAAAA,CAAaJ,CAAAA,CAAQ,MAAK,CAC5BI,CAAAA,CAAW,WAAgB,MAAA,GAC7B,OAAA,CAAQ,IAAI,SAAA,CAAeA,CAAAA,CAAW,QAAA,CACtC,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAqBA,EAAW,QAAA,CAAA,CAE1CA,CAAAA,CAAW,UAAe,MAAA,GAC5B,OAAA,CAAQ,IAAI,QAAA,CAAcA,CAAAA,CAAW,OAAA,CACrC,OAAA,CAAQ,GAAA,CAAI,cAAA,CAAoBA,EAAW,OAAA,CAAA,CAG7C,GAAM,CAAE,WAAA,CAAAC,CAAY,EAAI,MAAM,OAAO,oBAAW,CAAA,CAC5CF,CAAAA,CAAQ,GAAA,GAAQ,OAClBE,CAAAA,CAAYF,CAAAA,CAAQ,GAAG,CAAA,CAEvBE,CAAAA,GAGF,GAAM,CAAE,UAAA,CAAAC,CAAW,CAAA,CAAI,aAAa,mBAAU,CAAA,CACxCC,EAAS,MAAMD,CAAAA,CAAWJ,CAAQ,CAAA,CACxC,GAAI,CAACK,CAAAA,CAAO,OAAA,CAAS,CACfA,EAAO,OAAA,EAET,OAAA,CAAQ,MAAMA,CAAAA,CAAO,OAAO,EAG9B,IAAMC,CAAAA,CAAOD,CAAAA,CAAO,IAAA,EAAQ,CAAA,CAC5B,YAAA,CAAa,IAAM,OAAA,CAAQ,IAAA,CAAKC,CAAI,CAAC,CAAA,CACrC,MACF,
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"names":["major","minor","Command","program","err","filePath","options","globalOpts","loadEnvFile","runCommand","result","code"],"mappings":";AAUA,GAAM,CAACA,EAAOC,CAAK,CAAA,CAAI,QAAQ,OAAA,CAAQ,KAAA,CAAM,CAAC,CAAA,CAAE,KAAA,CAAM,GAAG,CAAA,CAAE,GAAA,CAAI,MAAM,CAAA,CAK/DD,CAAAA,CAAQ,IAAOA,CAAAA,GAAU,EAAA,EAAMC,CAAAA,EAAS,EAAA,GAE5C,OAAA,CAAQ,KAAA,CACN,wBAAwB,OAAA,CAAQ,OAAO,wJAGzC,CAAA,CACA,OAAA,CAAQ,KAAK,CAAC,CAAA,CAAA,CAIhB,GAAM,CAAE,OAAA,CAAAC,CAAQ,EAAI,MAAM,OAAO,WAAW,CAAA,CACtCC,CAAAA,CAAU,IAAID,CAAAA,CAEpBC,CAAAA,CACG,IAAA,CAAK,OAAO,CAAA,CACZ,WAAA,CAAY,2CAA2C,CAAA,CACvD,OAAA,CAAQ,gBAAgB,CAAA,CACxB,MAAA,CACC,sBACA,uDACF,CAAA,CACC,OACC,mBAAA,CACA,yDACF,EACC,wBAAA,EAAyB,CACzB,oBAAmB,CACnB,YAAA,CAAcC,GAAQ,CACjBA,CAAAA,CAAI,IAAA,GAAS,0BAAA,EACf,OAAA,CAAQ,IAAA,CAAK,CAAC,EAElB,CAAC,EAGC,OAAA,CAAQ,IAAA,CAAK,QAAU,CAAA,EACzBD,CAAAA,CAAQ,IAAA,CAAK,CAAE,KAAA,CAAO,KAAM,CAAC,CAAA,CAS/BA,CAAAA,CACG,QAAQ,KAAK,CAAA,CACb,YAAY,qDAAqD,CAAA,CACjE,QAAA,CAAS,QAAA,CAAU,kCAAkC,CAAA,CACrD,OACC,cAAA,CACA,6DACF,EACC,MAAA,CAAO,MAAOE,EAAUC,CAAAA,GAAY,CAEnC,IAAMC,CAAAA,CAAaJ,CAAAA,CAAQ,MAAK,CAC5BI,CAAAA,CAAW,WAAgB,MAAA,GAC7B,OAAA,CAAQ,IAAI,SAAA,CAAeA,CAAAA,CAAW,QAAA,CACtC,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAqBA,EAAW,QAAA,CAAA,CAE1CA,CAAAA,CAAW,UAAe,MAAA,GAC5B,OAAA,CAAQ,IAAI,QAAA,CAAcA,CAAAA,CAAW,OAAA,CACrC,OAAA,CAAQ,GAAA,CAAI,cAAA,CAAoBA,EAAW,OAAA,CAAA,CAG7C,GAAM,CAAE,WAAA,CAAAC,CAAY,EAAI,MAAM,OAAO,oBAAW,CAAA,CAC5CF,CAAAA,CAAQ,GAAA,GAAQ,OAClBE,CAAAA,CAAYF,CAAAA,CAAQ,GAAG,CAAA,CAEvBE,CAAAA,GAGF,GAAM,CAAE,UAAA,CAAAC,CAAW,CAAA,CAAI,aAAa,mBAAU,CAAA,CACxCC,EAAS,MAAMD,CAAAA,CAAWJ,CAAQ,CAAA,CACxC,GAAI,CAACK,CAAAA,CAAO,OAAA,CAAS,CACfA,EAAO,OAAA,EAET,OAAA,CAAQ,MAAMA,CAAAA,CAAO,OAAO,EAG9B,IAAMC,CAAAA,CAAOD,CAAAA,CAAO,IAAA,EAAQ,CAAA,CAC5B,YAAA,CAAa,IAAM,OAAA,CAAQ,IAAA,CAAKC,CAAI,CAAC,CAAA,CACrC,MACF,CAIF,CAAC,CAAA,CAGHR,CAAAA,CAAQ,KAAA,EAAM","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. Define program and parse; log options are global and applied before lazy-loading run/util (which load the logger)\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. CLI definition (only Commander; run/util are lazy-loaded so logger sees env) ─\nconst { Command } = await import(\"commander\");\nconst program = new Command();\n\nprogram\n .name(\"craft\")\n .description(\"A modern routing framework for TypeScript\")\n .version(\"0.3.0-canary.4\")\n .option(\n \"--log-level <level>\",\n \"Log level (e.g. info, warn, error, silent to disable)\",\n )\n .option(\n \"--log-file <path>\",\n \"Write logs to a file (keeps stdout clear for MCP stdio)\",\n )\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 // Apply global log options to env before any import that creates the logger\n const globalOpts = program.opts();\n if (globalOpts[\"logLevel\"] !== undefined) {\n process.env[\"LOG_LEVEL\"] = globalOpts[\"logLevel\"];\n process.env[\"CRAFT_LOG_LEVEL\"] = globalOpts[\"logLevel\"];\n }\n if (globalOpts[\"logFile\"] !== undefined) {\n process.env[\"LOG_FILE\"] = globalOpts[\"logFile\"];\n process.env[\"CRAFT_LOG_FILE\"] = globalOpts[\"logFile\"];\n }\n\n const { loadEnvFile } = await import(\"./util.js\");\n if (options.env !== undefined) {\n loadEnvFile(options.env);\n } else {\n loadEnvFile();\n }\n\n const { runCommand } = await import(\"./run.js\");\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 // Don't call process.exit() — let the event loop drain naturally.\n // process.exit() triggers C++ static destructors that race with ONNX\n // Runtime cleanup (onnxruntime#25038: \"mutex lock failed\").\n });\n\n// Parse the command line arguments and execute the appropriate command\nprogram.parse();\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {b}from'./chunk-
|
|
2
|
-
//# sourceMappingURL=run-
|
|
1
|
+
import {b}from'./chunk-MEHNJKKK.js';import {resolve,extname}from'path';import {logger,ContextBuilder,isRouteBuilder,isRouteDefinition}from'@routecraft/routecraft';var l=[".mjs",".js",".cjs"];async function C(t){let e=resolve(process.cwd(),t),o=extname(e);if(!l.includes(o))return {success:false,code:1,message:`Error: Only the following file types are supported: ${l.join(", ")}`};try{let s=await import(e),u=s.craftConfig;logger.info(`Loading file: ${e}`);let n=new ContextBuilder;u&&(logger.info("Found craftConfig export, applying configuration"),n.with(u));let i=R(n,s.default);if(!i.success)return i;let a=await n.build();return b(a),await a.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 R(t,e){return e?isRouteBuilder(e)?(t.routes(e),logger.info("Loaded single RouteBuilder from default export"),{success:true}):isRouteDefinition(e)?(t.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=>t.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{C as runCommand};//# sourceMappingURL=run-IJNIE5VV.js.map
|
|
2
|
+
//# sourceMappingURL=run-IJNIE5VV.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/run.ts"],"names":["SUPPORTED_EXTENSIONS","runCommand","filePath","absFilePath","resolve","ext","extname","module","craftConfig","logger","contextBuilder","ContextBuilder","configured","configureRoutes","context","registerContextSignalHandlers","error","defaultExport","isRouteBuilder","isRouteDefinition","item","routeOrBuilder"],"mappings":"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","file":"run-
|
|
1
|
+
{"version":3,"sources":["../src/run.ts"],"names":["SUPPORTED_EXTENSIONS","runCommand","filePath","absFilePath","resolve","ext","extname","module","craftConfig","logger","contextBuilder","ContextBuilder","configured","configureRoutes","context","registerContextSignalHandlers","error","defaultExport","isRouteBuilder","isRouteDefinition","item","routeOrBuilder"],"mappings":"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","file":"run-IJNIE5VV.js","sourcesContent":["import { resolve, extname } from \"node:path\";\nimport {\n ContextBuilder,\n type CraftConfig,\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 // 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 (CLI already set LOG_LEVEL / LOG_FILE from argv in index.ts).\n // Logger uses env first; context will apply craftConfig.log when built (env wins if set).\n const module = await import(absFilePath);\n const craftConfig = module.craftConfig as CraftConfig | undefined;\n\n logger.info(`Loading file: ${absFilePath}`);\n\n // Create context builder\n const contextBuilder = new ContextBuilder();\n\n // Apply craftConfig (routes, plugins, etc.); context applies config.log when built.\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"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":[],"names":[],"mappings":"","file":"util-
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","file":"util-5TR67ZZL.js"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@routecraft/cli",
|
|
3
|
-
"version": "0.3.0-canary.
|
|
3
|
+
"version": "0.3.0-canary.4",
|
|
4
4
|
"description": "CLI for running RouteCraft routes",
|
|
5
5
|
"private": false,
|
|
6
6
|
"type": "module",
|
|
@@ -22,9 +22,10 @@
|
|
|
22
22
|
"prepublishOnly": "pnpm run build"
|
|
23
23
|
},
|
|
24
24
|
"dependencies": {
|
|
25
|
-
"@routecraft/routecraft": "^0.3.0-canary.
|
|
25
|
+
"@routecraft/routecraft": "^0.3.0-canary.4",
|
|
26
26
|
"commander": "^14.0.3",
|
|
27
|
-
"dotenv": "^17.3.1"
|
|
27
|
+
"dotenv": "^17.3.1",
|
|
28
|
+
"pino-pretty": "^13.1.3"
|
|
28
29
|
},
|
|
29
30
|
"publishConfig": {
|
|
30
31
|
"access": "public"
|
package/dist/chunk-5NEKGUV3.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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/util-Q5GDRTSI.js
DELETED