@h3ravel/shared 0.17.3 → 0.18.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.
package/dist/index.js CHANGED
@@ -1,233 +1,213 @@
1
- var __defProp = Object.defineProperty;
2
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
1
+ import chalk from "chalk";
2
+ import nodepath from "path";
3
3
 
4
- // src/Contracts/IHttp.ts
5
- var HttpContext = class _HttpContext {
6
- static {
7
- __name(this, "HttpContext");
8
- }
9
- app;
10
- request;
11
- response;
12
- constructor(app, request, response) {
13
- this.app = app;
14
- this.request = request;
15
- this.response = response;
16
- }
17
- /**
18
- * Factory method to create a new HttpContext instance from a context object.
19
- * @param ctx - Object containing app, request, and response
20
- * @returns A new HttpContext instance
21
- */
22
- static init(ctx) {
23
- return new _HttpContext(ctx.app, ctx.request, ctx.response);
24
- }
4
+ //#region src/Contracts/IHttp.ts
5
+ /**
6
+ * Represents the HTTP context for a single request lifecycle.
7
+ * Encapsulates the application instance, request, and response objects.
8
+ */
9
+ var HttpContext = class HttpContext {
10
+ constructor(app, request, response) {
11
+ this.app = app;
12
+ this.request = request;
13
+ this.response = response;
14
+ }
15
+ /**
16
+ * Factory method to create a new HttpContext instance from a context object.
17
+ * @param ctx - Object containing app, request, and response
18
+ * @returns A new HttpContext instance
19
+ */
20
+ static init(ctx) {
21
+ /**
22
+ * Return a new instance
23
+ */
24
+ return new HttpContext(ctx.app, ctx.request, ctx.response);
25
+ }
25
26
  };
26
27
 
27
- // src/Utils/EnvParser.ts
28
+ //#endregion
29
+ //#region src/Utils/EnvParser.ts
28
30
  var EnvParser = class {
29
- static {
30
- __name(this, "EnvParser");
31
- }
32
- static parse(initial) {
33
- const parsed = {
34
- ...initial
35
- };
36
- for (const key in parsed) {
37
- let value = parsed[key];
38
- parsed[key] = this.parseValue(value);
39
- }
40
- return parsed;
41
- }
42
- static parseValue(value) {
43
- if (value === null || value === void 0) return value;
44
- if (value === "true") return true;
45
- if (value === "false") return false;
46
- if (!isNaN(value) && value.trim() !== "") {
47
- return Number(value);
48
- }
49
- if (value === "null") return null;
50
- if (value === "undefined") return void 0;
51
- return value;
52
- }
31
+ static parse(initial) {
32
+ const parsed = { ...initial };
33
+ for (const key in parsed) {
34
+ let value = parsed[key];
35
+ parsed[key] = this.parseValue(value);
36
+ }
37
+ return parsed;
38
+ }
39
+ static parseValue(value) {
40
+ /**
41
+ * Null/undefined stay untouched
42
+ */
43
+ if (value === null || value === void 0) return value;
44
+ /**
45
+ * Convert string "true"/"false" to boolean
46
+ */
47
+ if (value === "true") return true;
48
+ if (value === "false") return false;
49
+ /**
50
+ * Convert string numbers to number
51
+ */
52
+ if (!isNaN(value) && value.trim() !== "") return Number(value);
53
+ /**
54
+ * Convert string "null" and "undefined"
55
+ */
56
+ if (value === "null") return null;
57
+ if (value === "undefined") return void 0;
58
+ /**
59
+ * Otherwise return as-is (string)
60
+ */
61
+ return value;
62
+ }
53
63
  };
54
64
 
55
- // src/Utils/Logger.ts
56
- import chalk from "chalk";
65
+ //#endregion
66
+ //#region src/Utils/Logger.ts
57
67
  var Logger = class {
58
- static {
59
- __name(this, "Logger");
60
- }
61
- /**
62
- * Logs the message in two columns
63
- * @param name
64
- * @param value
65
- * @returns
66
- */
67
- static twoColumnLog(name, value) {
68
- const regex = /\x1b\[\d+m/g;
69
- const width = Math.min(process.stdout.columns, 100);
70
- const dots = Math.max(width - name.replace(regex, "").length - value.replace(regex, "").length - 10, 0);
71
- return console.log(name, chalk.gray(".".repeat(dots)), value);
72
- }
73
- /**
74
- * Wraps text with chalk
75
- *
76
- * @param txt
77
- * @param color
78
- * @returns
79
- */
80
- static textFormat(txt, color) {
81
- return String(txt).split(":").map((e, i, a) => i == 0 && a.length > 1 ? color(" " + e + ": ") : e).join("");
82
- }
83
- /**
84
- * Logs a success message
85
- *
86
- * @param msg
87
- * @param exit
88
- */
89
- static success(msg, exit = false) {
90
- console.log(chalk.green("\u2713"), this.textFormat(msg, chalk.bgGreen), "\n");
91
- if (exit) process.exit(0);
92
- }
93
- /**
94
- * Logs an informational message
95
- *
96
- * @param msg
97
- * @param exit
98
- */
99
- static info(msg, exit = false) {
100
- console.log(chalk.blue("\u2139"), this.textFormat(msg, chalk.bgBlue), "\n");
101
- if (exit) process.exit(0);
102
- }
103
- /**
104
- * Logs an error message
105
- *
106
- * @param msg
107
- * @param exit
108
- */
109
- static error(msg, exit = true) {
110
- if (msg instanceof Error) {
111
- if (msg.message) {
112
- console.error(chalk.red("\u2716"), this.textFormat("ERROR:" + msg.message, chalk.bgRed));
113
- }
114
- console.error(chalk.red(`${msg.detail ? `${msg.detail}
115
- ` : ""}${msg.stack}`), "\n");
116
- } else {
117
- console.error(chalk.red("\u2716"), this.textFormat(msg, chalk.bgRed), "\n");
118
- }
119
- if (exit) process.exit(1);
120
- }
121
- /**
122
- * Logs a success message
123
- *
124
- * @param name
125
- * @param value
126
- * @param status
127
- * @param exit
128
- */
129
- static split(name, value, status, exit = false) {
130
- status ??= "info";
131
- const color = {
132
- success: chalk.bgGreen,
133
- info: chalk.bgBlue,
134
- error: chalk.bgRed
135
- };
136
- const regex = /\x1b\[\d+m/g;
137
- const width = Math.min(process.stdout.columns, 100);
138
- const dots = Math.max(width - name.replace(regex, "").length - value.replace(regex, "").length - 10, 0);
139
- console.log(this.textFormat(name, color[status]), chalk.gray(".".repeat(dots)), value);
140
- if (exit) process.exit(0);
141
- }
142
- /**
143
- * Terminates the process
144
- */
145
- static quiet() {
146
- process.exit(0);
147
- }
148
- /**
149
- * Parse an array formated message and logs it
150
- *
151
- * @param config
152
- * @param joiner
153
- */
154
- static parse(config, joiner = " ") {
155
- const string = config.map(([str, opt]) => {
156
- return typeof chalk[opt] === "function" ? chalk[opt](str) : str;
157
- }).join(joiner);
158
- console.log(string);
159
- }
160
- static log(config, joiner) {
161
- if (typeof config === "string") {
162
- const conf = [
163
- [
164
- config,
165
- joiner
166
- ]
167
- ];
168
- return this.parse(conf);
169
- } else if (config) {
170
- return this.parse(config, joiner);
171
- }
172
- return this;
173
- }
68
+ static twoColumnLog(name, value, log = true) {
69
+ const regex = /\x1b\[\d+m/g;
70
+ const width = Math.min(process.stdout.columns, 100);
71
+ const dots = Math.max(width - name.replace(regex, "").length - value.replace(regex, "").length - 10, 0);
72
+ if (log) return console.log(name, chalk.gray(".".repeat(dots)), value);
73
+ else return [
74
+ name,
75
+ chalk.gray(".".repeat(dots)),
76
+ value
77
+ ];
78
+ }
79
+ /**
80
+ * Logs the message in two columns but allways passing status
81
+ *
82
+ * @param name
83
+ * @param value
84
+ * @param status
85
+ * @param exit
86
+ * @param preserveCol
87
+ */
88
+ static split(name, value, status, exit = false, preserveCol = false) {
89
+ status ??= "info";
90
+ const color = {
91
+ success: chalk.bgGreen,
92
+ info: chalk.bgBlue,
93
+ error: chalk.bgRed
94
+ };
95
+ const [_name, dots, val] = this.twoColumnLog(name, value, false);
96
+ console.log(this.textFormat(_name, color[status], preserveCol), dots, val);
97
+ if (exit) process.exit(0);
98
+ }
99
+ /**
100
+ * Wraps text with chalk
101
+ *
102
+ * @param txt
103
+ * @param color
104
+ * @param preserveCol
105
+ * @returns
106
+ */
107
+ static textFormat(txt, color, preserveCol = false) {
108
+ if (preserveCol) return String(txt);
109
+ return String(txt).split(":").map((e, i, a) => i == 0 && a.length > 1 ? color(" " + e + ": ") : e).join("");
110
+ }
111
+ /**
112
+ * Logs a success message
113
+ *
114
+ * @param msg
115
+ * @param exit
116
+ * @param preserveCol
117
+ */
118
+ static success(msg, exit = false, preserveCol = false) {
119
+ console.log(chalk.green("✓"), this.textFormat(msg, chalk.bgGreen, preserveCol), "\n");
120
+ if (exit) process.exit(0);
121
+ }
122
+ /**
123
+ * Logs an informational message
124
+ *
125
+ * @param msg
126
+ * @param exit
127
+ * @param preserveCol
128
+ */
129
+ static info(msg, exit = false, preserveCol = false) {
130
+ console.log(chalk.blue("ℹ"), this.textFormat(msg, chalk.bgBlue, preserveCol), "\n");
131
+ if (exit) process.exit(0);
132
+ }
133
+ /**
134
+ * Logs an error message
135
+ *
136
+ * @param msg
137
+ * @param exit
138
+ * @param preserveCol
139
+ */
140
+ static error(msg, exit = true, preserveCol = false) {
141
+ if (msg instanceof Error) {
142
+ if (msg.message) console.error(chalk.red("✖"), this.textFormat("ERROR:" + msg.message, chalk.bgRed, preserveCol));
143
+ console.error(chalk.red(`${msg.detail ? `${msg.detail}\n` : ""}${msg.stack}`), "\n");
144
+ } else console.error(chalk.red("✖"), this.textFormat(msg, chalk.bgRed, preserveCol), "\n");
145
+ if (exit) process.exit(1);
146
+ }
147
+ /**
148
+ * Terminates the process
149
+ */
150
+ static quiet() {
151
+ process.exit(0);
152
+ }
153
+ static parse(config, joiner = " ", log = true) {
154
+ const string = config.map(([str, opt]) => {
155
+ return typeof opt === "string" && typeof chalk[opt] === "function" ? chalk[opt](str) : typeof opt === "function" ? opt(str) : str;
156
+ }).join(joiner);
157
+ if (log) console.log(string);
158
+ else return string;
159
+ }
160
+ static log(config, joiner) {
161
+ if (typeof config === "string") {
162
+ const conf = [[config, joiner]];
163
+ return this.parse(conf);
164
+ } else if (config) return this.parse(config, joiner);
165
+ return this;
166
+ }
174
167
  };
175
168
 
176
- // src/Utils/PathLoader.ts
177
- import nodepath from "path";
169
+ //#endregion
170
+ //#region src/Utils/PathLoader.ts
178
171
  var PathLoader = class {
179
- static {
180
- __name(this, "PathLoader");
181
- }
182
- paths = {
183
- base: "",
184
- views: "/src/resources/views",
185
- assets: "/public/assets",
186
- routes: "/src/routes",
187
- config: "/src/config",
188
- public: "/public",
189
- storage: "/storage",
190
- database: "/src/database"
191
- };
192
- /**
193
- * Dynamically retrieves a path property from the class.
194
- * Any property ending with "Path" is accessible automatically.
195
- *
196
- * @param name - The base name of the path property
197
- * @param prefix - The base path to prefix to the path
198
- * @returns
199
- */
200
- getPath(name, prefix) {
201
- let path;
202
- if (prefix && name !== "base") {
203
- path = nodepath.join(prefix, this.paths[name]);
204
- } else {
205
- path = this.paths[name];
206
- }
207
- path = path.replace("/src/", `/${process.env.SRC_PATH ?? "src"}/`.replace(/([^:]\/)\/+/g, "$1"));
208
- if (name === "database" && process.env.SRC_PATH && !"/src/".includes(process.env.SRC_PATH)) {
209
- return nodepath.resolve(path.replace(process.env.SRC_PATH, ""));
210
- }
211
- return path;
212
- }
213
- /**
214
- * Programatically set the paths.
215
- *
216
- * @param name - The base name of the path property
217
- * @param path - The new path
218
- * @param base - The base path to include to the path
219
- */
220
- setPath(name, path, base) {
221
- if (base && name !== "base") {
222
- this.paths[name] = nodepath.join(base, path);
223
- }
224
- this.paths[name] = path;
225
- }
226
- };
227
- export {
228
- EnvParser,
229
- HttpContext,
230
- Logger,
231
- PathLoader
172
+ paths = {
173
+ base: "",
174
+ views: "/src/resources/views",
175
+ assets: "/public/assets",
176
+ routes: "/src/routes",
177
+ config: "/src/config",
178
+ public: "/public",
179
+ storage: "/storage",
180
+ database: "/src/database"
181
+ };
182
+ /**
183
+ * Dynamically retrieves a path property from the class.
184
+ * Any property ending with "Path" is accessible automatically.
185
+ *
186
+ * @param name - The base name of the path property
187
+ * @param prefix - The base path to prefix to the path
188
+ * @returns
189
+ */
190
+ getPath(name, prefix) {
191
+ let path;
192
+ if (prefix && name !== "base") path = nodepath.join(prefix, this.paths[name]);
193
+ else path = this.paths[name];
194
+ path = path.replace("/src/", `/${process.env.SRC_PATH ?? "src"}/`.replace(/([^:]\/)\/+/g, "$1"));
195
+ if (name === "database" && process.env.SRC_PATH && !"/src/".includes(process.env.SRC_PATH)) return nodepath.resolve(path.replace(process.env.SRC_PATH, ""));
196
+ return path;
197
+ }
198
+ /**
199
+ * Programatically set the paths.
200
+ *
201
+ * @param name - The base name of the path property
202
+ * @param path - The new path
203
+ * @param base - The base path to include to the path
204
+ */
205
+ setPath(name, path, base) {
206
+ if (base && name !== "base") this.paths[name] = nodepath.join(base, path);
207
+ this.paths[name] = path;
208
+ }
232
209
  };
210
+
211
+ //#endregion
212
+ export { EnvParser, HttpContext, Logger, PathLoader };
233
213
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/Contracts/IHttp.ts","../src/Utils/EnvParser.ts","../src/Utils/Logger.ts","../src/Utils/PathLoader.ts"],"sourcesContent":["import type { Middleware, MiddlewareOptions } from 'h3'\n\nimport { IApplication } from './IApplication'\nimport { IRequest } from './IRequest'\nimport { IResponse } from './IResponse'\n\nexport type RouterEnd = 'get' | 'delete' | 'put' | 'post' | 'patch' | 'apiResource' | 'group' | 'route';\n\n/**\n * Interface for the Router contract, defining methods for HTTP routing.\n */\nexport interface IRouter {\n /**\n * Registers a GET route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n get (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers a POST route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n post (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers a PUT route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n put (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers a DELETE route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n delete (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers an API resource with standard CRUD routes.\n * @param path - The base path for the resource.\n * @param controller - The controller class handling the resource.\n * @param middleware - Optional middleware array.\n */\n apiResource (\n path: string,\n controller: new (app: IApplication) => IController,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd | 'name'>;\n\n /**\n * Generates a URL for a named route.\n * @param name - The name of the route.\n * @param params - Optional parameters to replace in the route path.\n * @returns The generated URL or undefined if the route is not found.\n */\n route (name: string, params?: Record<string, string>): string | undefined;\n\n\n /**\n * Set the name of the current route\n * \n * @param name \n */\n name (name: string): this\n\n /**\n * Groups routes with shared prefix or middleware.\n * @param options - Configuration for prefix or middleware.\n * @param callback - Callback function defining grouped routes.\n */\n group (options: { prefix?: string; middleware?: EventHandler[] }, callback: () => this): this;\n\n /**\n * Registers middleware for a specific path.\n * @param path - The path to apply the middleware.\n * @param handler - The middleware handler.\n * @param opts - Optional middleware options.\n */\n middleware (path: string | IMiddleware[], handler: Middleware, opts?: MiddlewareOptions): this;\n}\n\n/**\n * Represents the HTTP context for a single request lifecycle.\n * Encapsulates the application instance, request, and response objects.\n */\nexport class HttpContext {\n constructor(\n public app: IApplication,\n public request: IRequest,\n public response: IResponse\n ) { }\n\n /**\n * Factory method to create a new HttpContext instance from a context object.\n * @param ctx - Object containing app, request, and response\n * @returns A new HttpContext instance\n */\n static init (ctx: { app: IApplication; request: IRequest; response: IResponse }): HttpContext {\n /**\n * Return a new instance\n */\n return new HttpContext(ctx.app, ctx.request, ctx.response);\n }\n}\n\n\n/**\n * Type for EventHandler, representing a function that handles an H3 event.\n */\nexport type EventHandler = (ctx: HttpContext) => any\nexport type RouteEventHandler = (...args: any[]) => any\n\n/**\n * Defines the contract for all controllers.\n * Any controller implementing this must define these methods.\n */\nexport interface IController {\n show (...ctx: any[]): any\n index (...ctx: any[]): any\n store (...ctx: any[]): any\n update (...ctx: any[]): any\n destroy (...ctx: any[]): any\n}\n\n/**\n * Defines the contract for all middlewares.\n * Any middleware implementing this must define these methods.\n */\nexport interface IMiddleware {\n handle (context: HttpContext, next: () => Promise<any>): Promise<any>\n} \n","import { GenericWithNullableStringValues } from '../Contracts/ObjContract';\n\nexport class EnvParser {\n\n static parse (initial: GenericWithNullableStringValues) {\n const parsed = { ...initial }\n\n for (const key in parsed) {\n let value: any = parsed[key]\n parsed[key] = this.parseValue(value)\n }\n\n return parsed\n }\n\n static parseValue (value: any) {\n /**\n * Null/undefined stay untouched \n */\n if (value === null || value === undefined) return value;\n\n /**\n * Convert string \"true\"/\"false\" to boolean \n */\n if (value === 'true') return true;\n if (value === 'false') return false;\n\n /**\n * Convert string numbers to number \n */\n if (!isNaN(value) && value.trim() !== '') {\n return Number(value);\n }\n\n /**\n * Convert string \"null\" and \"undefined\"\n */\n if (value === 'null') return null;\n if (value === 'undefined') return undefined;\n\n /**\n * Otherwise return as-is (string)\n */\n return value;\n }\n}\n","import chalk, { type ChalkInstance } from 'chalk'\n\nexport class Logger {\n /**\n * Logs the message in two columns\n * @param name \n * @param value \n * @returns \n */\n static twoColumnLog (name: string, value: string) {\n // eslint-disable-next-line no-control-regex\n const regex = /\\x1b\\[\\d+m/g\n const width = Math.min(process.stdout.columns, 100)\n const dots = Math.max(width - name.replace(regex, '').length - value.replace(regex, '').length - 10, 0)\n return console.log(name, chalk.gray('.'.repeat(dots)), value)\n }\n\n /**\n * Wraps text with chalk\n * \n * @param txt \n * @param color \n * @returns \n */\n static textFormat (txt: any, color: (txt: string) => string) {\n return String(txt).split(':').map((e, i, a) => i == 0 && a.length > 1 ? color(' ' + e + ': ') : e).join('')\n }\n\n /**\n * Logs a success message\n * \n * @param msg \n * @param exit \n */\n static success (msg: any, exit = false) {\n console.log(chalk.green('✓'), this.textFormat(msg, chalk.bgGreen), '\\n')\n if (exit) process.exit(0)\n }\n\n /**\n * Logs an informational message\n * \n * @param msg \n * @param exit \n */\n static info (msg: any, exit = false) {\n console.log(chalk.blue('ℹ'), this.textFormat(msg, chalk.bgBlue), '\\n')\n if (exit) process.exit(0)\n }\n\n /**\n * Logs an error message\n * \n * @param msg \n * @param exit \n */\n static error (msg: string | string[] | Error & { detail?: string }, exit = true) {\n if (msg instanceof Error) {\n if (msg.message) {\n console.error(chalk.red('✖'), this.textFormat('ERROR:' + msg.message, chalk.bgRed))\n }\n console.error(chalk.red(`${msg.detail ? `${msg.detail}\\n` : ''}${msg.stack}`), '\\n')\n }\n else {\n console.error(chalk.red('✖'), this.textFormat(msg, chalk.bgRed), '\\n')\n }\n if (exit) process.exit(1)\n }\n\n /**\n * Logs a success message\n * \n * @param name \n * @param value \n * @param status \n * @param exit \n */\n static split (name: string, value: string, status?: 'success' | 'info' | 'error', exit = false) {\n status ??= 'info'\n const color = { success: chalk.bgGreen, info: chalk.bgBlue, error: chalk.bgRed }\n const regex = /\\x1b\\[\\d+m/g\n const width = Math.min(process.stdout.columns, 100)\n const dots = Math.max(width - name.replace(regex, '').length - value.replace(regex, '').length - 10, 0)\n\n console.log(this.textFormat(name, color[status]), chalk.gray('.'.repeat(dots)), value)\n if (exit) process.exit(0)\n }\n\n /**\n * Terminates the process\n */\n static quiet () {\n process.exit(0)\n }\n\n /**\n * Parse an array formated message and logs it\n * \n * @param config \n * @param joiner \n */\n static parse (config: [string, keyof ChalkInstance][], joiner = ' ') {\n const string = config.map(([str, opt]) => {\n return typeof chalk[opt] === 'function' ? (chalk as any)[opt](str) : str\n }).join(joiner)\n\n console.log(string)\n }\n\n /**\n * Ouput formater object or format the output\n * \n * @returns \n */\n static log (): typeof Logger\n static log (config: string, joiner: keyof ChalkInstance): void\n static log (config: [string, keyof ChalkInstance][], joiner?: string): void\n static log (config?: string | [string, keyof ChalkInstance][], joiner?: string): void | Logger {\n if (typeof config === 'string') {\n const conf = [[config, joiner]] as [string, keyof ChalkInstance][]\n return this.parse(conf)\n } else if (config) {\n return this.parse(config, joiner)\n }\n return this\n }\n}\n","import { IPathName } from '../Contracts/IApplication'\nimport nodepath from 'path'\n\nexport class PathLoader {\n private paths = {\n base: '',\n views: '/src/resources/views',\n assets: '/public/assets',\n routes: '/src/routes',\n config: '/src/config',\n public: '/public',\n storage: '/storage',\n database: '/src/database',\n }\n\n /**\n * Dynamically retrieves a path property from the class.\n * Any property ending with \"Path\" is accessible automatically.\n *\n * @param name - The base name of the path property\n * @param prefix - The base path to prefix to the path\n * @returns \n */\n getPath (name: IPathName, prefix?: string): string {\n let path: string;\n\n if (prefix && name !== 'base') {\n path = nodepath.join(prefix, this.paths[name])\n } else {\n path = this.paths[name]\n }\n\n path = path.replace('/src/', `/${process.env.SRC_PATH ?? 'src'}/`.replace(/([^:]\\/)\\/+/g, \"$1\"))\n\n if (name === 'database' && process.env.SRC_PATH && !'/src/'.includes(process.env.SRC_PATH)) {\n return nodepath.resolve(path.replace(process.env.SRC_PATH, ''))\n }\n\n return path\n }\n\n /**\n * Programatically set the paths.\n *\n * @param name - The base name of the path property\n * @param path - The new path\n * @param base - The base path to include to the path\n */\n setPath (name: IPathName, path: string, base?: string) {\n if (base && name !== 'base') {\n this.paths[name] = nodepath.join(base, path)\n }\n\n this.paths[name] = path\n }\n}\n"],"mappings":"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","names":["HttpContext","app","request","response","init","ctx","EnvParser","parse","initial","parsed","key","value","parseValue","undefined","isNaN","trim","Number","chalk","Logger","twoColumnLog","name","value","regex","width","Math","min","process","stdout","columns","dots","max","replace","length","console","log","chalk","gray","repeat","textFormat","txt","color","String","split","map","e","i","a","join","success","msg","exit","green","bgGreen","info","blue","bgBlue","error","Error","message","red","bgRed","detail","stack","status","quiet","parse","config","joiner","string","str","opt","conf","nodepath","PathLoader","paths","base","views","assets","routes","config","public","storage","database","getPath","name","prefix","path","nodepath","join","replace","process","env","SRC_PATH","includes","resolve","setPath"]}
1
+ {"version":3,"file":"index.js","names":["app: IApplication","request: IRequest","response: IResponse","value: any","path: string"],"sources":["../src/Contracts/IHttp.ts","../src/Utils/EnvParser.ts","../src/Utils/Logger.ts","../src/Utils/PathLoader.ts"],"sourcesContent":["import type { Middleware, MiddlewareOptions } from 'h3'\n\nimport { IApplication } from './IApplication'\nimport { IRequest } from './IRequest'\nimport { IResponse } from './IResponse'\n\nexport type RouterEnd = 'get' | 'delete' | 'put' | 'post' | 'patch' | 'apiResource' | 'group' | 'route';\n\n/**\n * Interface for the Router contract, defining methods for HTTP routing.\n */\nexport interface IRouter {\n /**\n * Registers a GET route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n get (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers a POST route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n post (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers a PUT route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n put (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers a DELETE route.\n * @param path - The route path.\n * @param definition - The handler function or [controller class, method] array.\n * @param name - Optional route name.\n * @param middleware - Optional middleware array.\n */\n delete (\n path: string,\n definition: EventHandler | [(new (...args: any[]) => IController), methodName: string],\n name?: string,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd>;\n\n /**\n * Registers an API resource with standard CRUD routes.\n * @param path - The base path for the resource.\n * @param controller - The controller class handling the resource.\n * @param middleware - Optional middleware array.\n */\n apiResource (\n path: string,\n controller: new (app: IApplication) => IController,\n middleware?: IMiddleware[]\n ): Omit<this, RouterEnd | 'name'>;\n\n /**\n * Generates a URL for a named route.\n * @param name - The name of the route.\n * @param params - Optional parameters to replace in the route path.\n * @returns The generated URL or undefined if the route is not found.\n */\n route (name: string, params?: Record<string, string>): string | undefined;\n\n\n /**\n * Set the name of the current route\n * \n * @param name \n */\n name (name: string): this\n\n /**\n * Groups routes with shared prefix or middleware.\n * @param options - Configuration for prefix or middleware.\n * @param callback - Callback function defining grouped routes.\n */\n group (options: { prefix?: string; middleware?: EventHandler[] }, callback: () => this): this;\n\n /**\n * Registers middleware for a specific path.\n * @param path - The path to apply the middleware.\n * @param handler - The middleware handler.\n * @param opts - Optional middleware options.\n */\n middleware (path: string | IMiddleware[], handler: Middleware, opts?: MiddlewareOptions): this;\n}\n\n/**\n * Represents the HTTP context for a single request lifecycle.\n * Encapsulates the application instance, request, and response objects.\n */\nexport class HttpContext {\n constructor(\n public app: IApplication,\n public request: IRequest,\n public response: IResponse\n ) { }\n\n /**\n * Factory method to create a new HttpContext instance from a context object.\n * @param ctx - Object containing app, request, and response\n * @returns A new HttpContext instance\n */\n static init (ctx: { app: IApplication; request: IRequest; response: IResponse }): HttpContext {\n /**\n * Return a new instance\n */\n return new HttpContext(ctx.app, ctx.request, ctx.response);\n }\n}\n\n\n/**\n * Type for EventHandler, representing a function that handles an H3 event.\n */\nexport type EventHandler = (ctx: HttpContext) => any\nexport type RouteEventHandler = (...args: any[]) => any\n\n/**\n * Defines the contract for all controllers.\n * Any controller implementing this must define these methods.\n */\nexport interface IController {\n show (...ctx: any[]): any\n index (...ctx: any[]): any\n store (...ctx: any[]): any\n update (...ctx: any[]): any\n destroy (...ctx: any[]): any\n}\n\n/**\n * Defines the contract for all middlewares.\n * Any middleware implementing this must define these methods.\n */\nexport interface IMiddleware {\n handle (context: HttpContext, next: () => Promise<any>): Promise<any>\n} \n","import { GenericWithNullableStringValues } from '../Contracts/ObjContract';\n\nexport class EnvParser {\n\n static parse (initial: GenericWithNullableStringValues) {\n const parsed = { ...initial }\n\n for (const key in parsed) {\n let value: any = parsed[key]\n parsed[key] = this.parseValue(value)\n }\n\n return parsed\n }\n\n static parseValue (value: any) {\n /**\n * Null/undefined stay untouched \n */\n if (value === null || value === undefined) return value;\n\n /**\n * Convert string \"true\"/\"false\" to boolean \n */\n if (value === 'true') return true;\n if (value === 'false') return false;\n\n /**\n * Convert string numbers to number \n */\n if (!isNaN(value) && value.trim() !== '') {\n return Number(value);\n }\n\n /**\n * Convert string \"null\" and \"undefined\"\n */\n if (value === 'null') return null;\n if (value === 'undefined') return undefined;\n\n /**\n * Otherwise return as-is (string)\n */\n return value;\n }\n}\n","import chalk, { type ChalkInstance } from 'chalk'\n\nexport class Logger {\n /**\n * Logs the message in two columns\n * @param name \n * @param value \n * @param log If set to false, array of [name, dots, value] output will be returned and not logged \n * @returns \n */\n static twoColumnLog (name: string, value: string, log?: true): void\n static twoColumnLog (name: string, value: string, log?: false): [string, string, string]\n static twoColumnLog (name: string, value: string, log = true): [string, string, string] | void {\n // eslint-disable-next-line no-control-regex\n const regex = /\\x1b\\[\\d+m/g\n const width = Math.min(process.stdout.columns, 100)\n const dots = Math.max(width - name.replace(regex, '').length - value.replace(regex, '').length - 10, 0)\n\n if (log) return console.log(name, chalk.gray('.'.repeat(dots)), value)\n else return [name, chalk.gray('.'.repeat(dots)), value]\n }\n\n /**\n * Logs the message in two columns but allways passing status\n * \n * @param name \n * @param value \n * @param status \n * @param exit \n * @param preserveCol \n */\n static split (name: string, value: string, status?: 'success' | 'info' | 'error', exit = false, preserveCol = false) {\n status ??= 'info'\n const color = { success: chalk.bgGreen, info: chalk.bgBlue, error: chalk.bgRed }\n\n const [_name, dots, val] = this.twoColumnLog(name, value, false)\n\n console.log(this.textFormat(_name, color[status], preserveCol), dots, val)\n\n if (exit) process.exit(0)\n }\n\n /**\n * Wraps text with chalk\n * \n * @param txt \n * @param color \n * @param preserveCol \n * @returns \n */\n static textFormat (txt: any, color: (txt: string) => string, preserveCol = false) {\n if (preserveCol) return String(txt)\n return String(txt).split(':').map((e, i, a) => i == 0 && a.length > 1 ? color(' ' + e + ': ') : e).join('')\n }\n\n /**\n * Logs a success message\n * \n * @param msg \n * @param exit \n * @param preserveCol \n */\n static success (msg: any, exit = false, preserveCol = false) {\n console.log(chalk.green('✓'), this.textFormat(msg, chalk.bgGreen, preserveCol), '\\n')\n if (exit) process.exit(0)\n }\n\n /**\n * Logs an informational message\n * \n * @param msg \n * @param exit \n * @param preserveCol \n */\n static info (msg: any, exit = false, preserveCol = false) {\n console.log(chalk.blue('ℹ'), this.textFormat(msg, chalk.bgBlue, preserveCol), '\\n')\n if (exit) process.exit(0)\n }\n\n /**\n * Logs an error message\n * \n * @param msg \n * @param exit \n * @param preserveCol \n */\n static error (msg: string | string[] | Error & { detail?: string }, exit = true, preserveCol = false) {\n if (msg instanceof Error) {\n if (msg.message) {\n console.error(chalk.red('✖'), this.textFormat('ERROR:' + msg.message, chalk.bgRed, preserveCol))\n }\n console.error(chalk.red(`${msg.detail ? `${msg.detail}\\n` : ''}${msg.stack}`), '\\n')\n }\n else {\n console.error(chalk.red('✖'), this.textFormat(msg, chalk.bgRed, preserveCol), '\\n')\n }\n if (exit) process.exit(1)\n }\n\n /**\n * Terminates the process\n */\n static quiet () {\n process.exit(0)\n }\n\n /**\n * Parse an array formated message and logs it\n * \n * @param config \n * @param joiner \n * @param log If set to false, string output will be returned and not logged \n */\n static parse (config: [string, keyof ChalkInstance | ChalkInstance][], joiner?: string, log?: true): void\n static parse (config: [string, keyof ChalkInstance | ChalkInstance][], joiner?: string, log?: false): string\n static parse (config: [string, keyof ChalkInstance | ChalkInstance][], joiner = ' ', log = true): string | void {\n const string = config.map(([str, opt]) => {\n return typeof opt === 'string' && typeof chalk[opt] === 'function'\n ? (chalk as any)[opt](str)\n : typeof opt === 'function' ? opt(str) : str\n }).join(joiner)\n\n if (log) console.log(string)\n else return string\n }\n\n /**\n * Ouput formater object or format the output\n * \n * @returns \n */\n static log (): typeof Logger\n static log (config: string, joiner: keyof ChalkInstance): void\n static log (config: [string, keyof ChalkInstance][], joiner?: string): void\n static log (config?: string | [string, keyof ChalkInstance][], joiner?: string): void | Logger {\n if (typeof config === 'string') {\n const conf = [[config, joiner]] as [string, keyof ChalkInstance][]\n return this.parse(conf)\n } else if (config) {\n return this.parse(config, joiner)\n }\n return this\n }\n}\n","import { IPathName } from '../Contracts/IApplication'\nimport nodepath from 'path'\n\nexport class PathLoader {\n private paths = {\n base: '',\n views: '/src/resources/views',\n assets: '/public/assets',\n routes: '/src/routes',\n config: '/src/config',\n public: '/public',\n storage: '/storage',\n database: '/src/database',\n }\n\n /**\n * Dynamically retrieves a path property from the class.\n * Any property ending with \"Path\" is accessible automatically.\n *\n * @param name - The base name of the path property\n * @param prefix - The base path to prefix to the path\n * @returns \n */\n getPath (name: IPathName, prefix?: string): string {\n let path: string;\n\n if (prefix && name !== 'base') {\n path = nodepath.join(prefix, this.paths[name])\n } else {\n path = this.paths[name]\n }\n\n path = path.replace('/src/', `/${process.env.SRC_PATH ?? 'src'}/`.replace(/([^:]\\/)\\/+/g, \"$1\"))\n\n if (name === 'database' && process.env.SRC_PATH && !'/src/'.includes(process.env.SRC_PATH)) {\n return nodepath.resolve(path.replace(process.env.SRC_PATH, ''))\n }\n\n return path\n }\n\n /**\n * Programatically set the paths.\n *\n * @param name - The base name of the path property\n * @param path - The new path\n * @param base - The base path to include to the path\n */\n setPath (name: IPathName, path: string, base?: string) {\n if (base && name !== 'base') {\n this.paths[name] = nodepath.join(base, path)\n }\n\n this.paths[name] = path\n }\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@h3ravel/shared",
3
- "version": "0.17.3",
3
+ "version": "0.18.0",
4
4
  "description": "Shared Utilities.",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -44,7 +44,7 @@
44
44
  "laravel"
45
45
  ],
46
46
  "dependencies": {
47
- "h3": "^2.0.0-beta.1",
47
+ "h3": "^2.0.0-beta.4",
48
48
  "chalk": "^5.6.0",
49
49
  "edge.js": "^6.3.0"
50
50
  },
@@ -54,7 +54,7 @@
54
54
  "pnpm": "^10.14.0"
55
55
  },
56
56
  "scripts": {
57
- "build": "tsup",
57
+ "build": "tsdown --config-loader unconfig",
58
58
  "barrel": "barrelsby --directory src --delete --singleQuotes",
59
59
  "dev": "tsx watch src/index.ts",
60
60
  "start": "node dist/index.js",