kuwan-expresspack-core 0.1.17 → 0.1.19

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,13 @@
1
+ import { z } from 'zod';
2
+ import { config } from '@dotenvx/dotenvx';
3
+ import { colorize } from 'consola/utils';
4
+ import w from 'consola';
5
+
6
+ var m=colorize;function N(r){switch(typeof r){case "number":case "bigint":return colorize("cyan",r.toString());case "boolean":return colorize(r?"green":"red",String(r));case "symbol":return colorize("magenta",r.toString());case "string":return isNaN(Number(r))?colorize("whiteBright",`${r}`):colorize("yellow",`'${r}'`);case "undefined":return colorize("gray","undefined")}return r===null?colorize("dim","null"):String(r)}var P=w.create({level:Number.isNaN(Number(process.env.EXPRESSPACK_LOG_LEVEL))?3:Number(process.env.EXPRESSPACK_LOG_LEVEL)});function b(){let r=Number(process.env.EXPRESSPACK_LOG_LEVEL);P.level=Number.isNaN(r)?3:r;}var s=P;var d,c=null,v=null,y={},E=[];function I(r,n){let t=r.safeParse(n);if(t.success)return t.data;console.error("\u274C Invalid environment variables:"),console.error(z.prettifyError(t.error));}function R(r,n,t={fatal:false,immediate_log_error:true,log_error_after_graceful_start:true}){if(b(),y=t,t.fatal)try{let o=r.parse(n);return {...d,...o}}catch(o){throw o instanceof z.ZodError?(c=z.prettifyError(o),v=o,s.error("\u274C Invalid environment variables:"),s.error("\u274C",c),new Error("Invalid environment variables. The environment variable did not pass the schema validation. Check if you have set all required environment variables correctly.")):o}let i=r.safeParse(n);if(!i.success){let o=r.partial().safeParse(n);if(!o.success)return c=z.prettifyError(i.error),v=i.error,t.immediate_log_error&&(s.error("\u274C Invalid environment variables:"),s.error("\u274C",c)),d||{};c=z.prettifyError(i.error),v=i.error,t.immediate_log_error&&(s.error("\u274C Invalid environment variables:"),s.error("\u274C",c));let f=r.keyof();E=f.options;for(let p of f.options)p in o.data||(o.data[p]=void 0);return {...d,...o.data}}let a=r.keyof();E=a.options;for(let o of a.options)o in i.data||(i.data[o]=void 0);return {...d,...i.data}}function T(){return v}function S(){return c}function L(r){if(!r||Object.keys(r).length===0){s.warn("No environment variables to print. Make sure the env is complete and valid.");return}let n=e=>e.startsWith("* ")?m("dim",e):e,t=e=>E.includes(e)?e:`* ${e}`,i=e=>e.startsWith("! ")?m("dim",m("yellow",`${e}`)):e,a=e=>E.includes(e)&&r[e]===void 0?`! ${e}`:e,o=Object.entries(r).sort(([e],[l])=>e.localeCompare(l)).map(([e,l])=>[t(e),l]).map(([e,l])=>[a(e),l]),f=Math.max(...o.map(([e])=>e.length))+2,p=o.map(([e,l])=>`${e.padEnd(f," ").replace(e,n(e)).replace(e,i(e))} ${N(l)}`),_=`KEY${" ".repeat(f-3)} VALUE`,h=" ".repeat(_.length);return [h,_,h,...p].join(`
7
+ `)}function $(){if(y){let{log_error_after_graceful_start:r}=y;if(r){let n=S();n&&s.error("Invalid Environment Variable Value",`
8
+ -----
9
+ ${n}
10
+ -----`);}}}function k(r,n){s.log("[Environment Variables] on `env.ts`");let t=Object.fromEntries(Object.entries({...r}).map(([i,a])=>typeof a=="string"&&a.length>36?[i,`${a.slice(0,36)}...`]:n?n(i,a):[i,a]));s.log(`${L(t)}
11
+ `);}function C(r){d={};let n=config(r);return b(),d=n.parsed?n.parsed:void 0,n}function K(r){return new Proxy(r,{get(n,t){return t in n?n[t]:process.env[t]}})}function j(r,n,t){let i=R(r,n,t);return K(i)}var H={create:j,parseEnv:I,prettifyEnv:L,getEnvErrorRaw:T,getEnvErrorString:S,logEnvErrors:$,config:C};
12
+
13
+ export { s as a, R as b, T as c, S as d, L as e, $ as f, k as g, C as h, H as i };
@@ -1,3 +1,3 @@
1
- import { g } from './chunk-CZGPAGDK.mjs';
1
+ import { h } from './chunk-XWAHBJNF.mjs';
2
2
 
3
- g();
3
+ h();
package/dist/env.d.ts CHANGED
@@ -55,6 +55,13 @@ declare function prettifyEnv(env: Record<string, any>): string | undefined;
55
55
  * Errors are already logged after by graceful start.
56
56
  */
57
57
  declare function logEnvErrors(): void;
58
+ /**
59
+ * This will print the passed env vars regardless of the NODE_ENV,
60
+ * it is on your discretion on when to call this function.
61
+ *
62
+ * @param envVars The environment variables to log
63
+ */
64
+ declare function debugEnvVars(envVars: Record<string, any>, redactFunction?: (key: string, value: any) => [string, any]): void;
58
65
  declare function config(options?: DotenvConfigOptions | undefined): DotenvConfigOutput;
59
66
  declare function createProxy<T extends z.ZodObject<any>>(schema: T, data: unknown, options?: Partial<EnvOptions>): z.output<T>;
60
67
  declare const _default: {
@@ -67,4 +74,4 @@ declare const _default: {
67
74
  config: typeof config;
68
75
  };
69
76
 
70
- export { type EnvOptions, config, create, _default as default, getEnvErrorRaw, getEnvErrorString, logEnvErrors, prettifyEnv };
77
+ export { type EnvOptions, config, create, debugEnvVars, _default as default, getEnvErrorRaw, getEnvErrorString, logEnvErrors, prettifyEnv };
package/dist/env.mjs CHANGED
@@ -1 +1 @@
1
- export { g as config, b as create, h as default, c as getEnvErrorRaw, d as getEnvErrorString, f as logEnvErrors, e as prettifyEnv } from './chunk-CZGPAGDK.mjs';
1
+ export { h as config, b as create, g as debugEnvVars, i as default, c as getEnvErrorRaw, d as getEnvErrorString, f as logEnvErrors, e as prettifyEnv } from './chunk-XWAHBJNF.mjs';
package/dist/index.d.ts CHANGED
@@ -67,12 +67,35 @@ declare function loadKernel({ app }: {
67
67
 
68
68
  declare function createRouter(options?: RouterOptions): Router;
69
69
 
70
+ interface DefineRouteMiddlewareContext {
71
+ app?: Express;
72
+ router: Router;
73
+ }
74
+ interface DefineRouterMiddlewareReturn {
75
+ (app?: Express): Router;
76
+ }
70
77
  /**
71
78
  * Utility to define a router middleware using a callback.
72
79
  * @param fn Callback to register routes on the router
73
80
  * @returns Express Router instance
81
+ *
82
+ * @example
83
+ *
84
+ * ```ts
85
+ * const routerMiddleware = defineRouterMiddleware(({ router, app }) => {
86
+ * router.get('/hello', (req, res) => {
87
+ * res.send('Hello from router middleware!');
88
+ * });
89
+ *
90
+ * app.use(controller);
91
+ * });
92
+ *
93
+ * // In your main app file
94
+ * const app = express();
95
+ * app.use(middlewares);
96
+ * routerMiddleware(app);
74
97
  */
75
- declare function defineRouterMiddleware(fn: (r: Router) => void, options?: RouterOptions): Router;
98
+ declare function defineRouterMiddleware(fn: (context: DefineRouteMiddlewareContext) => void, options?: RouterOptions): DefineRouterMiddlewareReturn;
76
99
 
77
100
  /**
78
101
  * Load all configurations from the config directory
package/dist/index.mjs CHANGED
@@ -1,15 +1,15 @@
1
1
  import { e } from './chunk-OXUMMLIO.mjs';
2
2
  import { a as a$1 } from './chunk-JKH5TYED.mjs';
3
3
  import { a as a$2 } from './chunk-VSPZT4K6.mjs';
4
- import { a, f } from './chunk-CZGPAGDK.mjs';
4
+ import { a, f } from './chunk-XWAHBJNF.mjs';
5
5
  import { Router } from 'express';
6
- import M, { relative, join } from 'path';
6
+ import O, { relative, join } from 'path';
7
7
  import { existsSync } from 'fs';
8
8
  import { glob } from 'tinyglobby';
9
9
  import { pathToFileURL } from 'url';
10
10
 
11
- function A(r,t,e$1){return r.listen(t,async()=>{e$1&&(a.debug("Executing onStart hook..."),await e$1().catch(i=>{a.error("Error during onStart hook:",i);})),a.box({message:`Server is running at http://localhost:${t}`,style:{borderColor:"cyan"},level:"info"});try{await e.emit("app:mounted",{app:r});}catch(i){a.error("Error during app:mounted event:",i);}finally{f();}})}function F(r,t){process.on("SIGINT",async()=>{a.info("Received SIGINT. Shutting down gracefully..."),await new Promise(e=>{r.close(async s=>s instanceof Error?(a.error("Error shutting down server:",s),e()):(t&&await t().catch(i=>{a.error("Error during shutdown hook:",i);}),a.info("Server has been shut down."),e()));}),process.exit(0);});}function T(r){return r}function $(r){return r}async function L({app:r},t){a.debug("Loading kernel...");let{kernel:e,kernel2:s,listener:i,appBootstrap:d}=t,p=s;if(e&&typeof e=="function"&&(p=e),p&&typeof p=="function")try{let n=await p(),l=typeof n=="object"&&n!==null&&"default"in n?n.default:n;typeof l=="function"?(await l({app:r}),a.debug("Middleware kernel loaded.")):a.warn("Middleware kernel setup function not found.");}catch(n){throw a.error("Error loading middleware kernel:",n),n}if(i&&typeof i=="function")try{await a$1(i);}catch(n){throw a.error("Error loading listener:",n),n}if(d&&typeof d=="function")try{await d({app:r});}catch(n){throw a.error("Error during boot process:",n),n}a.debug("Kernel loaded.");}function g(r){return Router(r)}function B(r,t){let e=g(t);return r(e),e}function b(r){let t=join(r,"expresspack.config"),e=join(r,"app"),s=join(r,"config"),i=join(s,"app"),d=join(s,"body-parser"),p=join(e,"controllers"),n=join(e,"services"),l=join(e,"errors"),u=join(e,"middlewares"),m=join(e,"routes");return {rc:t,root:r,app:e,middlewareFilePath:u,routesFilePath:m,config:{base:s,bodyParserFile:d,appConfigFile:i},controllers:{base:p},services:{base:n},errors:{base:l}}}var R=r=>{let t=["ts","mts","js","mjs","cjs","cts"];for(let e of t){let s=`${r}.${e}`;if(existsSync(s))return s}return null},k=r=>existsSync(r)?r:null;function C(r){if(!r)return "";let t=M.sep;return r.endsWith(t)?r:r+t}var D="*.{js,ts,mjs,cjs,mts,cts}",I=["!*.d.{ts,mts,mjs,cts}","!*.map"];async function S(r){let t=await glob([D,...I],{cwd:r}),e=new Set;return t.forEach(s=>{let i=s.replace(/\.(js|ts|mjs|cjs|mts|cts)$/,"");e.add(i);}),Array.from(e)}async function U(r){let{config:t}=b(r),e=t.base;if(a.debug("Loading all configurations from: `"+C(relative(r,t.base)+"`")),!k(e)){a.debug("No config directory found. Looked for:",e);return}let i=await S(e);a.debug(`Found ${i.length} config files: %s`,`
12
- ${i.join(`
13
- `)}`);for(let p of i){let n=R(join(e,p));if(!n){a.warn(`No config file found for topic: ${p}`);continue}try{let u=await import(pathToFileURL(n).href),m=u.default||u;typeof m=="function"&&(m=await m());let x=p.replace(/[-_](\w)/g,(H,y)=>y?y.toUpperCase():"");a$2[x]=m;let j=relative(r,n);a.debug(`Loaded config: \`${x}\` from \`${j}\``);}catch(l){a.error(`Failed to load config ${p}:`,l);}}}
11
+ function A(e$1,t,r){return e$1.listen(t,async()=>{r&&(a.debug("Executing onStart hook..."),await r().catch(s=>{a.error("Error during onStart hook:",s);})),a.box({message:`Server is running at http://localhost:${t}`,style:{borderColor:"cyan"},level:"info"});try{await e.emit("app:mounted",{app:e$1});}catch(s){a.error("Error during app:mounted event:",s);}finally{f();}})}function F(e,t){process.on("SIGINT",async()=>{a.info("Received SIGINT. Shutting down gracefully..."),await new Promise(r=>{e.close(async i=>i instanceof Error?(a.error("Error shutting down server:",i),r()):(t&&await t().catch(s=>{a.error("Error during shutdown hook:",s);}),a.info("Server has been shut down."),r()));}),process.exit(0);});}function T(e){return e}function M(e){return e}async function $({app:e},t){a.debug("Loading kernel...");let{kernel:r,kernel2:i,listener:s,appBootstrap:l}=t,p=i;if(r&&typeof r=="function"&&(p=r),p&&typeof p=="function")try{let n=await p(),d=typeof n=="object"&&n!==null&&"default"in n?n.default:n;typeof d=="function"?(await d({app:e}),a.debug("Middleware kernel loaded.")):a.warn("Middleware kernel setup function not found.");}catch(n){throw a.error("Error loading middleware kernel:",n),n}if(s&&typeof s=="function")try{await a$1(s);}catch(n){throw a.error("Error loading listener:",n),n}if(l&&typeof l=="function")try{await l({app:e});}catch(n){throw a.error("Error during boot process:",n),n}a.debug("Kernel loaded.");}function g(e){return Router(e)}function D(e,t){return r=>{let i=g(t);return e({app:r,router:i}),i}}function P(e){let t=join(e,"expresspack.config"),r=join(e,"app"),i=join(e,"config"),s=join(i,"app"),l=join(i,"body-parser"),p=join(r,"controllers"),n=join(r,"services"),d=join(r,"errors"),m=join(r,"middlewares"),u=join(r,"routes");return {rc:t,root:e,app:r,middlewareFilePath:m,routesFilePath:u,config:{base:i,bodyParserFile:l,appConfigFile:s},controllers:{base:p},services:{base:n},errors:{base:d}}}var b=e=>{let t=["ts","mts","js","mjs","cjs","cts"];for(let r of t){let i=`${e}.${r}`;if(existsSync(i))return i}return null},C=e=>existsSync(e)?e:null;function k(e){if(!e)return "";let t=O.sep;return e.endsWith(t)?e:e+t}var N="*.{js,ts,mjs,cjs,mts,cts}",I=["!*.d.{ts,mts,mjs,cts}","!*.map"];async function S(e){let t=await glob([N,...I],{cwd:e}),r=new Set;return t.forEach(i=>{let s=i.replace(/\.(js|ts|mjs|cjs|mts|cts)$/,"");r.add(s);}),Array.from(r)}async function U(e){let{config:t}=P(e),r=t.base;if(a.debug("Loading all configurations from: `"+k(relative(e,t.base)+"`")),!C(r)){a.debug("No config directory found. Looked for:",r);return}let s=await S(r);a.debug(`Found ${s.length} config files: %s`,`
12
+ ${s.join(`
13
+ `)}`);for(let p of s){let n=b(join(r,p));if(!n){a.warn(`No config file found for topic: ${p}`);continue}try{let m=await import(pathToFileURL(n).href),u=m.default||m;typeof u=="function"&&(u=await u());let x=p.replace(/[-_](\w)/g,(H,w)=>w?w.toUpperCase():"");a$2[x]=u;let j=relative(e,n);a.debug(`Loaded config: \`${x}\` from \`${j}\``);}catch(d){a.error(`Failed to load config ${p}:`,d);}}}
14
14
 
15
- export { U as configLoader, g as createRouter, T as defineKernel, $ as defineMiddlewareKernel, B as defineRouterMiddleware, A as gracefulHTTPStart, F as gracefulShutdown, L as loadKernel };
15
+ export { U as configLoader, g as createRouter, T as defineKernel, M as defineMiddlewareKernel, D as defineRouterMiddleware, A as gracefulHTTPStart, F as gracefulShutdown, $ as loadKernel };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "kuwan-expresspack-core",
3
- "version": "0.1.17",
3
+ "version": "0.1.19",
4
4
  "description": "",
5
5
  "type": "module",
6
6
  "main": "./dist/index.mjs",
@@ -1,12 +0,0 @@
1
- import { z as z$1 } from 'zod';
2
- import { config } from '@dotenvx/dotenvx';
3
- import { colorize } from 'consola/utils';
4
- import L from 'consola';
5
-
6
- var m=colorize;function N(r){switch(typeof r){case "number":case "bigint":return colorize("cyan",r.toString());case "boolean":return colorize(r?"green":"red",String(r));case "symbol":return colorize("magenta",r.toString());case "string":return isNaN(Number(r))?colorize("whiteBright",`${r}`):colorize("yellow",`'${r}'`);case "undefined":return colorize("gray","undefined")}return r===null?colorize("dim","null"):String(r)}var P=L.create({level:Number.isNaN(Number(process.env.EXPRESSPACK_LOG_LEVEL))?3:Number(process.env.EXPRESSPACK_LOG_LEVEL)});function b(){let r=Number(process.env.EXPRESSPACK_LOG_LEVEL);P.level=Number.isNaN(r)?3:r;}var s=P;var c,l=null,v=null,y={},E=[];function z(r,n){let o=r.safeParse(n);if(o.success)return o.data;console.error("\u274C Invalid environment variables:"),console.error(z$1.prettifyError(o.error));}function I(r,n,o={fatal:false,immediate_log_error:true,log_error_after_graceful_start:true}){if(b(),y=o,o.fatal)try{let t=r.parse(n);return {...c,...t}}catch(t){throw t instanceof z$1.ZodError?(l=z$1.prettifyError(t),v=t,s.error("\u274C Invalid environment variables:"),s.error("\u274C",l),new Error("Invalid environment variables. The environment variable did not pass the schema validation. Check if you have set all required environment variables correctly.")):t}let i=r.safeParse(n);if(!i.success){let t=r.partial().safeParse(n);if(!t.success)return l=z$1.prettifyError(i.error),v=i.error,o.immediate_log_error&&(s.error("\u274C Invalid environment variables:"),s.error("\u274C",l)),c||{};l=z$1.prettifyError(i.error),v=i.error,o.immediate_log_error&&(s.error("\u274C Invalid environment variables:"),s.error("\u274C",l));let d=r.keyof();E=d.options;for(let p of d.options)p in t.data||(t.data[p]=void 0);return {...c,...t.data}}let g=r.keyof();E=g.options;for(let t of g.options)t in i.data||(i.data[t]=void 0);return {...c,...i.data}}function R(){return v}function S(){return l}function T(r){if(!r||Object.keys(r).length===0){s.warn("No environment variables to print. Make sure the env is complete and valid.");return}let n=e=>e.startsWith("* ")?m("dim",e):e,o=e=>E.includes(e)?e:`* ${e}`,i=e=>e.startsWith("! ")?m("dim",m("yellow",`${e}`)):e,g=e=>E.includes(e)&&r[e]===void 0?`! ${e}`:e,t=Object.entries(r).sort(([e],[u])=>e.localeCompare(u)).map(([e,u])=>[o(e),u]).map(([e,u])=>[g(e),u]),d=Math.max(...t.map(([e])=>e.length))+2,p=t.map(([e,u])=>`${e.padEnd(d," ").replace(e,n(e)).replace(e,i(e))} ${N(u)}`),_=`KEY${" ".repeat(d-3)} VALUE`,h=" ".repeat(_.length);return [h,_,h,...p].join(`
7
- `)}function C(){if(y){let{log_error_after_graceful_start:r}=y;if(r){let n=S();n&&s.error("Invalid Environment Variable Value",`
8
- -----
9
- ${n}
10
- -----`);}}}function K(r){c={};let n=config(r);return b(),c=n.parsed?n.parsed:void 0,n}function $(r){return new Proxy(r,{get(n,o){return o in n?n[o]:process.env[o]}})}function j(r,n,o){let i=I(r,n,o);return $(i)}var Y={create:j,parseEnv:z,prettifyEnv:T,getEnvErrorRaw:R,getEnvErrorString:S,logEnvErrors:C,config:K};
11
-
12
- export { s as a, I as b, R as c, S as d, T as e, C as f, K as g, Y as h };