@h3ravel/core 1.9.0 → 1.9.2

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.
@@ -26,6 +26,8 @@ declare global {
26
26
  function config<X extends Record<string, any>, T extends Extract<keyof X, string>> (key: T, def?: any): X[T];
27
27
  function config<T extends Record<string, any>> (key: T): void;
28
28
 
29
+ function view (viewPath: string, params?: Record<string, any> | undefined): Promise<string>
30
+
29
31
  /**
30
32
  * Get app path
31
33
  *
package/dist/index.cjs CHANGED
@@ -120,7 +120,7 @@ var ContainerResolver = class ContainerResolver {
120
120
  /**
121
121
  * Resolve the bound dependencies
122
122
  */
123
- let args = params.filter((e) => ContainerResolver.isClass(e)).map((type) => {
123
+ const args = params.filter((e) => ContainerResolver.isClass(e)).map((type) => {
124
124
  return this.app.make(type);
125
125
  });
126
126
  return new Promise((resolve) => {
@@ -151,7 +151,7 @@ var Registerer = class Registerer {
151
151
  globalThis.database_path = (path$1) => this.databasePath(path$1);
152
152
  }
153
153
  appPath(path$1) {
154
- return this.app.getPath("base", node_path.default.join(`/${process.env.SRC_PATH ?? "src"}/`.replace(/([^:]\/)\/+/g, "$1"), "app", path$1 ?? ""));
154
+ return this.app.getPath("base", node_path.default.join(`/${process.env.DIST_DIR ?? "src"}/`.replace(/([^:]\/)\/+/g, "$1"), "app", path$1 ?? ""));
155
155
  }
156
156
  basePath(path$1) {
157
157
  return this.app.getPath("base", path$1);
@@ -340,7 +340,7 @@ var Application = class Application extends Container {
340
340
  hostname,
341
341
  silent: true
342
342
  });
343
- __h3ravel_shared.Logger.parse([[`🚀 H3ravel running at:`, "green"], [`${server.options.protocol ?? "http"}://${server.options.hostname}:${server.options.port}`, "cyan"]]);
343
+ __h3ravel_shared.Logger.parse([["🚀 H3ravel running at:", "green"], [`${server.options.protocol ?? "http"}://${server.options.hostname}:${server.options.port}`, "cyan"]]);
344
344
  } else if (this.tries <= tries) {
345
345
  await this.fire(h3App, realPort);
346
346
  this.tries++;
@@ -454,6 +454,7 @@ var ConsoleCommand = class {
454
454
  this.dictionary = dictionary;
455
455
  this.input.options = options;
456
456
  this.input.arguments = regArgs.map((e, i) => ({ [e.name()]: args[i] })).reduce((e, x) => Object.assign(e, x), {});
457
+ this.loadBaseFlags();
457
458
  }
458
459
  getSignature() {
459
460
  return this.signature;
@@ -474,6 +475,12 @@ var ConsoleCommand = class {
474
475
  arguments() {
475
476
  return this.input.arguments;
476
477
  }
478
+ loadBaseFlags() {
479
+ this.input.options.lock = this.program.getOptionValue("lock") ?? false;
480
+ this.input.options.quiet = this.program.getOptionValue("quiet") ?? false;
481
+ this.input.options.silent = this.program.getOptionValue("silent") ?? false;
482
+ this.input.options.verbose = this.program.getOptionValue("verbose") ?? 0;
483
+ }
477
484
  };
478
485
 
479
486
  //#endregion
@@ -563,13 +570,25 @@ var Kernel = class {
563
570
  const ctx = this.context(event);
564
571
  const { app } = ctx.request;
565
572
  /**
566
- * Dynamically bind the view renderer to the service container.
567
- * This allows any part of the request lifecycle to render templates using Edge.
573
+ * Initialize the view handler method
574
+ *
575
+ * @param template
576
+ * @param params
577
+ * @returns
568
578
  */
569
- app.bind("view", () => async (template, params) => {
579
+ const view = async (template, params) => {
570
580
  const edge = app.make("edge");
571
581
  return ctx.response.html(await edge.render(template, params));
572
- });
582
+ };
583
+ /**
584
+ * Bind the view method to the global variable space
585
+ */
586
+ globalThis.view = view;
587
+ /**
588
+ * Dynamically bind the view renderer to the service container.
589
+ * This allows any part of the request lifecycle to render templates using Edge.
590
+ */
591
+ app.bind("view", () => view);
573
592
  /**
574
593
  * Run middleware stack and obtain result
575
594
  */
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":["dependencies: any[]","app: Application","params: any[]","args: any[]","app: Application","dd","dump","path","nodepath","PathLoader","port: number","tries: number","hostname: string","e: any","path","app: Application","kernel: ConsoleKernel","Logger","app: Application","context: (event: H3Event) => HttpContext","middleware: IMiddleware[]","Edge"],"sources":["../src/Container.ts","../src/Di/ContainerResolver.ts","../src/Registerer.ts","../src/Application.ts","../src/Console/ConsoleCommand.ts","../src/Console/ConsoleKernel.ts","../src/Controller.ts","../src/Di/Inject.ts","../src/Http/Kernel.ts","../src/ServiceProvider.ts","../src/Providers/CoreServiceProvider.ts","../src/Providers/ViewServiceProvider.ts"],"sourcesContent":["import type { Bindings, IContainer, UseKey } from '@h3ravel/shared'\n\ntype IBinding = UseKey | (new (..._args: any[]) => unknown)\n\nexport class Container implements IContainer {\n private bindings = new Map<IBinding, () => unknown>()\n private singletons = new Map<IBinding, unknown>()\n\n /**\n * Check if the target has any decorators\n * \n * @param target \n * @returns \n */\n static hasAnyDecorator (target: Function): boolean {\n if (Reflect.getMetadataKeys(target).length > 0) return true\n\n const paramLength = target.length\n\n for (let i = 0; i < paramLength; i++) {\n if (Reflect.getMetadataKeys(target, `__param_${i}`).length > 0) {\n return true\n }\n }\n\n return false\n }\n\n /**\n * Bind a transient service to the container\n */\n bind<T> (key: new (...args: any[]) => T, factory: () => T): void\n bind<T extends UseKey> (key: T, factory: () => Bindings[T]): void\n bind<T extends UseKey> (\n key: T,\n factory: () => Bindings[T] | T\n ) {\n this.bindings.set(key, factory)\n }\n\n /**\n * Bind a singleton service to the container\n */\n singleton<T extends UseKey> (\n key: T | (new (..._args: any[]) => Bindings[T]),\n factory: () => Bindings[T]\n ) {\n this.bindings.set(key, () => {\n if (!this.singletons.has(key)) {\n this.singletons.set(key, factory())\n }\n return this.singletons.get(key)!\n })\n }\n\n /**\n * Resolve a service from the container\n */\n make<T extends UseKey, X = undefined> (\n key: T | (new (..._args: any[]) => Bindings[T])\n ): X extends undefined ? Bindings[T] : X {\n /**\n * Direct factory binding\n */\n if (this.bindings.has(key)) {\n return this.bindings.get(key)!() as Bindings[T]\n }\n\n /**\n * If this is a class constructor, auto-resolve via reflection\n */\n if (typeof key === 'function') {\n return this.build(key)\n }\n\n throw new Error(\n `No binding found for key: ${typeof key === 'string' ? key : (key as any)?.name}`\n )\n }\n\n /**\n * Automatically build a class with constructor dependency injection\n */\n private build<T extends UseKey> (ClassType: new (..._args: any[]) => Bindings[T]): Bindings[T] {\n let dependencies: any[] = [];\n\n if (Array.isArray((ClassType as any).__inject__)) {\n dependencies = (ClassType as any).__inject__.map((alias: any) => {\n return this.make(alias)\n });\n } else {\n const paramTypes: any[] = Reflect.getMetadata('design:paramtypes', ClassType) || []\n dependencies = paramTypes.map((dep) => this.make(dep))\n }\n\n return new ClassType(...dependencies);\n }\n\n /**\n * Check if a service is registered\n */\n has (key: UseKey): boolean {\n return this.bindings.has(key)\n }\n}\n","import 'reflect-metadata';\n\nimport { Application } from '..';\n\nexport class ContainerResolver {\n constructor(private app: Application) { }\n\n async resolveMethodParams<I extends Record<string, any>> (instance: I, method: keyof I, _default?: any) {\n /**\n * Get param types for instance method\n */\n let params: any[] = Reflect.getMetadata('design:paramtypes', instance, String(method)) || [];\n\n /**\n * Ensure that the Application class is always available\n */\n if (params.length < 1 && _default) {\n params = [_default]\n }\n\n /**\n * Resolve the bound dependencies\n */\n let args: any[] = params.filter(e => ContainerResolver.isClass(e)).map((type: any) => {\n return this.app.make(type)\n });\n\n return new Promise<I>((resolve) => {\n resolve(instance[method](...args))\n })\n }\n\n static isClass (C: any) {\n return typeof C === \"function\" &&\n C.prototype !== undefined &&\n Object.toString.call(C).substring(0, 5) === 'class'\n }\n}\n","import { dd, dump } from '@h3ravel/support'\n\nimport { Application } from '.'\nimport nodepath from 'node:path'\n\nexport class Registerer {\n constructor(private app: Application) { }\n\n static register (app: Application) {\n const reg = new Registerer(app)\n reg.bootRegister()\n }\n\n bootRegister () {\n globalThis.dd = dd\n globalThis.dump = dump\n globalThis.app_path = (path?: string) => this.appPath(path)\n globalThis.base_path = (path?: string) => this.basePath(path)\n globalThis.public_path = (path?: string) => this.publicPath(path)\n globalThis.storage_path = (path?: string) => this.storagePath(path)\n globalThis.database_path = (path?: string) => this.databasePath(path)\n }\n\n private appPath (path?: string) {\n return this.app.getPath(\n 'base', nodepath.join(`/${process.env.SRC_PATH ?? 'src'}/`.replace(/([^:]\\/)\\/+/g, \"$1\"), 'app', path ?? '')\n )\n }\n\n private basePath (path?: string) {\n return this.app.getPath('base', path)\n }\n\n private publicPath (path?: string) {\n return this.app.getPath('public', path)\n }\n\n private storagePath (path?: string) {\n return this.app.getPath('base', nodepath.join('storage', path ?? ''))\n }\n\n private databasePath (path?: string) {\n return this.app.getPath('database', path)\n }\n}\n","import 'reflect-metadata';\n\nimport { IApplication, IPathName, IServiceProvider, Logger } from '@h3ravel/shared'\n\nimport { Container } from './Container'\nimport { ContainerResolver } from './Di/ContainerResolver';\nimport type { H3 } from 'h3'\nimport { PathLoader } from '@h3ravel/shared'\nimport { Registerer } from './Registerer'\nimport chalk from 'chalk';\nimport { detect } from 'detect-port';\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\n\ntype AServiceProvider = (new (_app: Application) => IServiceProvider) & IServiceProvider\n\nexport class Application extends Container implements IApplication {\n public paths = new PathLoader()\n private tries: number = 0\n private booted = false\n private versions = { app: '0', ts: '0' }\n private basePath: string\n\n private providers: IServiceProvider[] = []\n protected externalProviders: Array<new (_app: Application) => IServiceProvider> = []\n\n /**\n * List of registered console commands\n */\n public registeredCommands: (new (app: any, kernel: any) => any)[] = [];\n\n constructor(basePath: string) {\n super()\n\n dotenvExpand.expand(dotenv.config({ quiet: true }))\n\n this.basePath = basePath\n this.setPath('base', basePath)\n this.loadOptions()\n this.registerBaseBindings();\n Registerer.register(this)\n }\n\n /**\n * Register core bindings into the container\n */\n protected registerBaseBindings () {\n this.bind(Application, () => this)\n this.bind('path.base', () => this.basePath)\n this.bind('load.paths', () => this.paths)\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n for (const ProviderClass of providers) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n protected async loadOptions () {\n const app = await this.safeImport(this.getPath('base', 'package.json'))\n const core = await this.safeImport('../package.json')\n\n if (app && app.dependencies) {\n this.versions.app = app.dependencies['@h3ravel/core']\n }\n if (core && core.devDependencies) {\n this.versions.ts = app.devDependencies.typescript\n }\n }\n\n /**\n * Get all registered providers\n */\n public getRegisteredProviders () {\n return this.providers;\n }\n\n /**\n * Load default and optional providers dynamically\n * \n * Auto-Registration Behavior\n * \n * Minimal App: Loads only core, config, http, router by default.\n * Full-Stack App: Installs database, mail, queue, cache → they self-register via their providers.\n */\n protected async getConfiguredProviders (): Promise<Array<AServiceProvider>> {\n return [\n (await import('@h3ravel/core')).CoreServiceProvider,\n (await import('@h3ravel/core')).ViewServiceProvider,\n ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders();\n const allProviders = [...coreProviders, ...this.externalProviders];\n\n /**\n * Deduplicate by class reference\n */\n const uniqueProviders = Array.from(new Set(allProviders));\n\n return this.sortProviders(uniqueProviders);\n }\n\n private sortProviders (providers: Array<AServiceProvider>) {\n const priorityMap = new Map<string, number>();\n\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n priorityMap.set(Provider.name, (Provider as any).priority ?? 0);\n });\n\n /**\n * Handle before/after adjustments\n */\n providers.forEach((Provider) => {\n const order = (Provider as any).order;\n if (!order) return;\n\n const [direction, target] = order.split(':');\n const targetPriority = priorityMap.get(target) ?? 0;\n\n if (direction === 'before') {\n priorityMap.set(Provider.name, targetPriority - 1);\n } else if (direction === 'after') {\n priorityMap.set(Provider.name, targetPriority + 1);\n }\n });\n\n /**\n * Service providers sorted based on thier name and priority\n */\n const sorted = providers.sort(\n (A, B) => (priorityMap.get(B.name) ?? 0) - (priorityMap.get(A.name) ?? 0)\n );\n\n /**\n * If debug is enabled, let's show the loaded service provider info\n */\n if (process.env.APP_DEBUG === 'true' && process.env.EXTENDED_DEBUG !== 'false' && !sorted.some(e => e.console)) {\n console.table(\n sorted.map((P) => ({\n Provider: P.name,\n Priority: priorityMap.get(P.name),\n Order: (P as any).order || 'N/A',\n }))\n );\n\n console.info(`Set ${chalk.bgCyan(' APP_DEBUG = false ')} in your .env file to hide this information`, \"\\n\")\n }\n\n return sorted\n }\n\n registerProviders (providers: Array<AServiceProvider>): void {\n this.externalProviders.push(...providers)\n }\n\n /**\n * Register a provider\n */\n public async register (provider: IServiceProvider) {\n await new ContainerResolver(this).resolveMethodParams(provider, 'register', this)\n if (provider.registeredCommands && provider.registeredCommands.length > 0) {\n this.registeredCommands.push(...provider.registeredCommands)\n }\n this.providers.push(provider)\n }\n\n /**\n * checks if the application is running in CLI\n */\n public runningInConsole (): boolean {\n return typeof process !== 'undefined'\n && !!process.stdout\n && !!process.stdin\n\n }\n\n public getRuntimeEnv (): 'browser' | 'node' | 'unknown' {\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n return 'browser'\n }\n if (typeof process !== 'undefined' && process.versions?.node) {\n return 'node'\n }\n return 'unknown'\n }\n\n /**\n * Boot all service providers after registration\n */\n public async boot () {\n if (this.booted) return\n\n for (const provider of this.providers) {\n if (provider.boot) {\n if (Container.hasAnyDecorator(provider.boot)) {\n /**\n * If the service provider is decorated use the IoC container\n */\n await this.make<any>(provider.boot)\n } else {\n /**\n * Otherwise instantiate manually so that we can at least\n * pass the app instance\n */\n await provider.boot(this)\n }\n }\n }\n\n this.booted = true\n }\n\n /**\n * Fire up the developement server using the user provided arguments\n * \n * Port will be auto assigned if provided one is not available\n * \n * @param h3App The current H3 app instance\n * @param preferedPort If provided, this will overide the port set in the evironment\n */\n public async fire (h3App: H3, preferedPort?: number) {\n const serve = this.make('http.serve')\n\n const port: number = preferedPort ?? env('PORT', 3000)\n const tries: number = env('RETRIES', 1)\n const hostname: string = env('HOSTNAME', 'localhost')\n\n try {\n const realPort = await detect(port)\n\n if (port == realPort) {\n const server = serve(h3App, {\n port,\n hostname,\n silent: true,\n })\n\n Logger.parse([\n [`🚀 H3ravel running at:`, 'green'],\n [`${server.options.protocol ?? 'http'}://${server.options.hostname}:${server.options.port}`, 'cyan']]\n )\n } else if (this.tries <= tries) {\n await this.fire(h3App, realPort)\n this.tries++\n } else {\n Logger.parse([\n ['ERROR:', 'bgRed'],\n ['No free port available', 'red'],\n ])\n }\n } catch (e: any) {\n Logger.parse([\n ['An error occured', 'bgRed'],\n [e.message, 'red'],\n [e.stack, 'red']\n ], \"\\n\")\n }\n }\n\n /**\n * Attempt to dynamically import an optional module\n */\n private async safeImport (moduleName: string) {\n try {\n const mod = await import(moduleName)\n return mod.default ?? mod ?? {}\n } catch {\n return null\n }\n }\n\n /**\n * Get the base path of the app\n * \n * @returns \n */\n getBasePath (): string {\n return this.basePath\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 * @returns \n */\n getPath (name: IPathName, suffix?: string) {\n return path.join(this.paths.getPath(name, this.basePath), suffix ?? '')\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 * @returns \n */\n setPath (name: IPathName, path: string) {\n return this.paths.setPath(name, path, this.basePath)\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n getVersion (key: 'app' | 'ts') {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n}\n","import type { Argument, Command } from \"commander\";\n\nimport { Application } from \"../Application\";\nimport { ConsoleKernel } from \"./ConsoleKernel\";\nimport { XGeneric } from \"@h3ravel/support\";\n\nexport class ConsoleCommand {\n constructor(protected app: Application, protected kernel: ConsoleKernel) { }\n\n /**\n * The underlying commander instance.\n *\n * @var Command\n */\n public program!: Command;\n\n /**\n * The name and signature of the console command.\n *\n * @var string\n */\n protected signature!: string;\n\n /**\n * A dictionary of signatures or what not.\n *\n * @var object\n */\n protected dictionary: Record<string, any> = {}\n\n /**\n * The console command description.\n *\n * @var string\n */\n protected description?: string;\n\n /**\n * The console command input.\n *\n * @var object\n */\n private input: XGeneric<{ options: Record<string, any>, arguments: Record<string, any> }> = {\n options: {},\n arguments: {},\n }\n\n /**\n * Execute the console command.\n */\n public async handle (..._args: any[]): Promise<void> { }\n\n setApplication (app: Application) {\n this.app = app\n }\n\n setInput (\n options: XGeneric,\n args: string[],\n regArgs: readonly Argument[],\n dictionary: Record<string, any>,\n program: Command,\n ) {\n this.program = program\n this.dictionary = dictionary\n this.input.options = options\n this.input.arguments = regArgs\n .map((e, i) => ({ [e.name()]: args[i] }))\n .reduce((e, x) => Object.assign(e, x), {})\n }\n\n getSignature () {\n return this.signature\n }\n\n getDescription () {\n return this.description\n }\n\n option (key: string, def?: any) {\n return this.input.options[key] ?? def\n }\n\n options (key?: string) {\n if (key) {\n return this.input.options[key]\n }\n return this.input.options\n }\n\n argument (key: string, def?: any) {\n return this.input.arguments[key] ?? def\n }\n\n arguments () {\n return this.input.arguments\n }\n}\n","import { Application } from \"../Application\";\nimport { Logger } from \"@h3ravel/shared\";\nimport { XGeneric } from \"@h3ravel/support\";\nimport { mkdir } from \"node:fs/promises\";\n\nexport class ConsoleKernel {\n public cwd!: string\n public output = typeof Logger\n public basePath: string = ''\n public modulePath!: string\n public consolePath!: string\n public modulePackage!: XGeneric<{ version: string }>\n public consolePackage!: XGeneric<{ version: string }>\n\n constructor(public app: Application) { }\n\n async ensureDirectoryExists (dir: string) {\n await mkdir(dir, { recursive: true })\n }\n}\n","import { Application } from '.'\nimport { IController } from '@h3ravel/shared'\n\n/**\n * Base controller class\n */\nexport abstract class Controller implements IController {\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n public show (..._ctx: any[]): any { return }\n public index (..._ctx: any[]): any { return }\n public store (..._ctx: any[]): any { return }\n public update (..._ctx: any[]): any { return }\n public destroy (..._ctx: any[]): any { return }\n}\n","export function Inject (...dependencies: string[]) {\n return function (target: any) {\n target.__inject__ = dependencies;\n };\n}\n\n/**\n * Allows binding dependencies to both class and class methods \n * \n * @returns \n */\nexport function Injectable (): ClassDecorator & MethodDecorator {\n return (...args: any[]) => {\n if (args.length === 1) {\n void args[0]; // class target\n }\n if (args.length === 3) {\n void args[0]; // target\n void args[1]; // propertyKey\n void args[2]; // descriptor\n }\n };\n}\n\n// export function Injectable (): MethodDecorator & ClassDecorator {\n// return ((_target: any, _propertyKey?: string, descriptor?: PropertyDescriptor) => {\n// if (descriptor) {\n// const original = descriptor.value;\n// descriptor.value = async function (...args: any[]) {\n// const resolvedArgs = await Promise.all(args);\n// return original.apply(this, resolvedArgs);\n// };\n// }\n// }) as any;\n// }\n","import { HttpContext, IMiddleware } from '@h3ravel/shared'\n\nimport type { H3Event } from 'h3'\n\n/**\n * Kernel class handles middleware execution and response transformations.\n * It acts as the core middleware pipeline for HTTP requests.\n */\nexport class Kernel {\n /**\n * @param context - A factory function that converts an H3Event into an HttpContext.\n * @param middleware - An array of middleware classes that will be executed in sequence.\n */\n constructor(\n protected context: (event: H3Event) => HttpContext,\n protected middleware: IMiddleware[] = [],\n ) { }\n\n /**\n * Handles an incoming request and passes it through middleware before invoking the next handler.\n * \n * @param event - The raw H3 event object.\n * @param next - A callback function that represents the next layer (usually the controller or final handler).\n * @returns A promise resolving to the result of the request pipeline.\n */\n async handle (\n event: H3Event,\n next: (ctx: HttpContext) => Promise<unknown>\n ): Promise<unknown> {\n /**\n * Convert the raw event into a standardized HttpContext\n */\n const ctx = this.context(event)\n const { app } = ctx.request\n\n /**\n * Dynamically bind the view renderer to the service container.\n * This allows any part of the request lifecycle to render templates using Edge.\n */\n app.bind('view', () => async (template: string, params?: Record<string, any>) => {\n const edge = app.make('edge')\n return ctx.response.html(await edge.render(template, params))\n })\n\n /**\n * Run middleware stack and obtain result\n */\n const result = await this.runMiddleware(ctx, () => next(ctx))\n\n /**\n * If a plain object is returned from a controller or middleware,\n * automatically set the JSON Content-Type header for the response.\n */\n if (result !== undefined && this.isPlainObject(result)) {\n event.res.headers.set('Content-Type', 'application/json; charset=UTF-8')\n }\n\n return result\n }\n\n /**\n * Sequentially runs middleware in the order they were registered.\n * \n * @param context - The standardized HttpContext.\n * @param next - Callback to execute when middleware completes.\n * @returns A promise resolving to the final handler's result.\n */\n private async runMiddleware (\n context: HttpContext,\n next: (ctx: HttpContext) => Promise<unknown>\n ) {\n let index = -1\n\n const runner = async (i: number): Promise<unknown> => {\n if (i <= index) throw new Error('next() called multiple times')\n index = i\n const middleware = this.middleware[i]\n\n if (middleware) {\n /**\n * Execute the current middleware and proceed to the next one\n */\n return middleware.handle(context, () => runner(i + 1))\n } else {\n /**\n * If no more middleware, call the final handler\n */\n return next(context)\n }\n }\n\n return runner(0)\n }\n\n /**\n * Utility function to determine if a value is a plain object or array.\n * \n * @param value - The value to check.\n * @returns True if the value is a plain object or array, otherwise false.\n */\n private isPlainObject (value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' &&\n value !== null &&\n (value.constructor === Object || value.constructor === Array)\n }\n}\n","import { Application } from './Application'\nimport { IServiceProvider } from '@h3ravel/shared'\n\nexport abstract class ServiceProvider implements IServiceProvider {\n /**\n * Sort order\n */\n\n public static order?: `before:${string}` | `after:${string}` | string | undefined;\n\n /**\n * Sort priority\n */\n public static priority = 0;\n\n /**\n * Indicate that this service provider only runs in console\n */\n public static console = false;\n\n /**\n * List of registered console commands\n */\n public registeredCommands?: (new (app: any, kernel: any) => any)[];\n\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n /**\n * Register bindings to the container.\n * Runs before boot().\n */\n abstract register (...app: unknown[]): void | Promise<void>;\n\n /**\n * Perform post-registration booting of services.\n * Runs after all providers have been registered.\n */\n boot?(...app: unknown[]): void | Promise<void>;\n\n /**\n * An array of console commands to register.\n */\n commands (commands: (new (app: any, kernel: any) => any)[]): void {\n this.registeredCommands = commands\n }\n}\n","import 'reflect-metadata'\n\nimport { ServiceProvider } from '../ServiceProvider'\n\n/**\n * Bootstraps core services and bindings.\n * \n * Bind essential services to the container (logger, config repository).\n * Register app-level singletons.\n * Set up exception handling.\n * \n * Auto-Registered\n */\nexport class CoreServiceProvider extends ServiceProvider {\n public static priority = 999;\n\n register () {\n }\n}\n","import { Edge } from 'edge.js'\nimport { ServiceProvider } from '../ServiceProvider'\n\nexport class ViewServiceProvider extends ServiceProvider {\n public static priority = 995;\n\n register (): void {\n const config = this.app.make('config')\n const edge = Edge.create({\n cache: process.env.NODE_ENV === 'production'\n })\n\n edge.mount(this.app.getPath('views'))\n\n edge.global('asset', this.app.make('asset'))\n edge.global('config', config.get)\n edge.global('app', this.app)\n\n this.app.bind('edge', () => edge)\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","names":["dependencies: any[]","app: Application","params: any[]","args: any[]","app: Application","dd","dump","path","nodepath","PathLoader","port: number","tries: number","hostname: string","e: any","path","app: Application","kernel: ConsoleKernel","Logger","app: Application","context: (event: H3Event) => HttpContext","middleware: IMiddleware[]","Edge"],"sources":["../src/Container.ts","../src/Di/ContainerResolver.ts","../src/Registerer.ts","../src/Application.ts","../src/Console/ConsoleCommand.ts","../src/Console/ConsoleKernel.ts","../src/Controller.ts","../src/Di/Inject.ts","../src/Http/Kernel.ts","../src/ServiceProvider.ts","../src/Providers/CoreServiceProvider.ts","../src/Providers/ViewServiceProvider.ts"],"sourcesContent":["import type { Bindings, IContainer, UseKey } from '@h3ravel/shared'\n\ntype IBinding = UseKey | (new (..._args: any[]) => unknown)\n\nexport class Container implements IContainer {\n private bindings = new Map<IBinding, () => unknown>()\n private singletons = new Map<IBinding, unknown>()\n\n /**\n * Check if the target has any decorators\n * \n * @param target \n * @returns \n */\n static hasAnyDecorator (target: (...prm: any[]) => any): boolean {\n if (Reflect.getMetadataKeys(target).length > 0) return true\n\n const paramLength = target.length\n\n for (let i = 0; i < paramLength; i++) {\n if (Reflect.getMetadataKeys(target, `__param_${i}`).length > 0) {\n return true\n }\n }\n\n return false\n }\n\n /**\n * Bind a transient service to the container\n */\n bind<T> (key: new (...args: any[]) => T, factory: () => T): void\n bind<T extends UseKey> (key: T, factory: () => Bindings[T]): void\n bind<T extends UseKey> (\n key: T,\n factory: () => Bindings[T] | T\n ) {\n this.bindings.set(key, factory)\n }\n\n /**\n * Bind a singleton service to the container\n */\n singleton<T extends UseKey> (\n key: T | (new (..._args: any[]) => Bindings[T]),\n factory: () => Bindings[T]\n ) {\n this.bindings.set(key, () => {\n if (!this.singletons.has(key)) {\n this.singletons.set(key, factory())\n }\n return this.singletons.get(key)!\n })\n }\n\n /**\n * Resolve a service from the container\n */\n make<T extends UseKey, X = undefined> (\n key: T | (new (..._args: any[]) => Bindings[T])\n ): X extends undefined ? Bindings[T] : X {\n /**\n * Direct factory binding\n */\n if (this.bindings.has(key)) {\n return this.bindings.get(key)!() as Bindings[T]\n }\n\n /**\n * If this is a class constructor, auto-resolve via reflection\n */\n if (typeof key === 'function') {\n return this.build(key)\n }\n\n throw new Error(\n `No binding found for key: ${typeof key === 'string' ? key : (key as any)?.name}`\n )\n }\n\n /**\n * Automatically build a class with constructor dependency injection\n */\n private build<T extends UseKey> (ClassType: new (..._args: any[]) => Bindings[T]): Bindings[T] {\n let dependencies: any[] = []\n\n if (Array.isArray((ClassType as any).__inject__)) {\n dependencies = (ClassType as any).__inject__.map((alias: any) => {\n return this.make(alias)\n })\n } else {\n const paramTypes: any[] = Reflect.getMetadata('design:paramtypes', ClassType) || []\n dependencies = paramTypes.map((dep) => this.make(dep))\n }\n\n return new ClassType(...dependencies)\n }\n\n /**\n * Check if a service is registered\n */\n has (key: UseKey): boolean {\n return this.bindings.has(key)\n }\n}\n","import 'reflect-metadata'\n\nimport { Application } from '..'\n\nexport class ContainerResolver {\n constructor(private app: Application) { }\n\n async resolveMethodParams<I extends Record<string, any>> (instance: I, method: keyof I, _default?: any) {\n /**\n * Get param types for instance method\n */\n let params: any[] = Reflect.getMetadata('design:paramtypes', instance, String(method)) || []\n\n /**\n * Ensure that the Application class is always available\n */\n if (params.length < 1 && _default) {\n params = [_default]\n }\n\n /**\n * Resolve the bound dependencies\n */\n const args: any[] = params.filter(e => ContainerResolver.isClass(e)).map((type: any) => {\n return this.app.make(type)\n })\n\n return new Promise<I>((resolve) => {\n resolve(instance[method](...args))\n })\n }\n\n static isClass (C: any) {\n return typeof C === 'function' &&\n C.prototype !== undefined &&\n Object.toString.call(C).substring(0, 5) === 'class'\n }\n}\n","import { dd, dump } from '@h3ravel/support'\n\nimport { Application } from '.'\nimport nodepath from 'node:path'\n\nexport class Registerer {\n constructor(private app: Application) { }\n\n static register (app: Application) {\n const reg = new Registerer(app)\n reg.bootRegister()\n }\n\n bootRegister () {\n globalThis.dd = dd\n globalThis.dump = dump\n globalThis.app_path = (path?: string) => this.appPath(path)\n globalThis.base_path = (path?: string) => this.basePath(path)\n globalThis.public_path = (path?: string) => this.publicPath(path)\n globalThis.storage_path = (path?: string) => this.storagePath(path)\n globalThis.database_path = (path?: string) => this.databasePath(path)\n }\n\n private appPath (path?: string) {\n return this.app.getPath(\n 'base', nodepath.join(`/${process.env.DIST_DIR ?? 'src'}/`.replace(/([^:]\\/)\\/+/g, '$1'), 'app', path ?? '')\n )\n }\n\n private basePath (path?: string) {\n return this.app.getPath('base', path)\n }\n\n private publicPath (path?: string) {\n return this.app.getPath('public', path)\n }\n\n private storagePath (path?: string) {\n return this.app.getPath('base', nodepath.join('storage', path ?? ''))\n }\n\n private databasePath (path?: string) {\n return this.app.getPath('database', path)\n }\n}\n","import 'reflect-metadata'\n\nimport { IApplication, IPathName, IServiceProvider, Logger } from '@h3ravel/shared'\n\nimport { Container } from './Container'\nimport { ContainerResolver } from './Di/ContainerResolver'\nimport type { H3 } from 'h3'\nimport { PathLoader } from '@h3ravel/shared'\nimport { Registerer } from './Registerer'\nimport chalk from 'chalk'\nimport { detect } from 'detect-port'\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\n\ntype AServiceProvider = (new (_app: Application) => IServiceProvider) & IServiceProvider\n\nexport class Application extends Container implements IApplication {\n public paths = new PathLoader()\n private tries: number = 0\n private booted = false\n private versions = { app: '0', ts: '0' }\n private basePath: string\n\n private providers: IServiceProvider[] = []\n protected externalProviders: Array<new (_app: Application) => IServiceProvider> = []\n\n /**\n * List of registered console commands\n */\n public registeredCommands: (new (app: any, kernel: any) => any)[] = []\n\n constructor(basePath: string) {\n super()\n\n dotenvExpand.expand(dotenv.config({ quiet: true }))\n\n this.basePath = basePath\n this.setPath('base', basePath)\n this.loadOptions()\n this.registerBaseBindings()\n Registerer.register(this)\n }\n\n /**\n * Register core bindings into the container\n */\n protected registerBaseBindings () {\n this.bind(Application, () => this)\n this.bind('path.base', () => this.basePath)\n this.bind('load.paths', () => this.paths)\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n for (const ProviderClass of providers) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n protected async loadOptions () {\n const app = await this.safeImport(this.getPath('base', 'package.json'))\n const core = await this.safeImport('../package.json')\n\n if (app && app.dependencies) {\n this.versions.app = app.dependencies['@h3ravel/core']\n }\n if (core && core.devDependencies) {\n this.versions.ts = app.devDependencies.typescript\n }\n }\n\n /**\n * Get all registered providers\n */\n public getRegisteredProviders () {\n return this.providers\n }\n\n /**\n * Load default and optional providers dynamically\n * \n * Auto-Registration Behavior\n * \n * Minimal App: Loads only core, config, http, router by default.\n * Full-Stack App: Installs database, mail, queue, cache → they self-register via their providers.\n */\n protected async getConfiguredProviders (): Promise<Array<AServiceProvider>> {\n return [\n (await import('@h3ravel/core')).CoreServiceProvider,\n (await import('@h3ravel/core')).ViewServiceProvider,\n ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders()\n const allProviders = [...coreProviders, ...this.externalProviders]\n\n /**\n * Deduplicate by class reference\n */\n const uniqueProviders = Array.from(new Set(allProviders))\n\n return this.sortProviders(uniqueProviders)\n }\n\n private sortProviders (providers: Array<AServiceProvider>) {\n const priorityMap = new Map<string, number>()\n\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n priorityMap.set(Provider.name, (Provider as any).priority ?? 0)\n })\n\n /**\n * Handle before/after adjustments\n */\n providers.forEach((Provider) => {\n const order = (Provider as any).order\n if (!order) return\n\n const [direction, target] = order.split(':')\n const targetPriority = priorityMap.get(target) ?? 0\n\n if (direction === 'before') {\n priorityMap.set(Provider.name, targetPriority - 1)\n } else if (direction === 'after') {\n priorityMap.set(Provider.name, targetPriority + 1)\n }\n })\n\n /**\n * Service providers sorted based on thier name and priority\n */\n const sorted = providers.sort(\n (A, B) => (priorityMap.get(B.name) ?? 0) - (priorityMap.get(A.name) ?? 0)\n )\n\n /**\n * If debug is enabled, let's show the loaded service provider info\n */\n if (process.env.APP_DEBUG === 'true' && process.env.EXTENDED_DEBUG !== 'false' && !sorted.some(e => e.console)) {\n console.table(\n sorted.map((P) => ({\n Provider: P.name,\n Priority: priorityMap.get(P.name),\n Order: (P as any).order || 'N/A',\n }))\n )\n\n console.info(`Set ${chalk.bgCyan(' APP_DEBUG = false ')} in your .env file to hide this information`, '\\n')\n }\n\n return sorted\n }\n\n registerProviders (providers: Array<AServiceProvider>): void {\n this.externalProviders.push(...providers)\n }\n\n /**\n * Register a provider\n */\n public async register (provider: IServiceProvider) {\n await new ContainerResolver(this).resolveMethodParams(provider, 'register', this)\n if (provider.registeredCommands && provider.registeredCommands.length > 0) {\n this.registeredCommands.push(...provider.registeredCommands)\n }\n this.providers.push(provider)\n }\n\n /**\n * checks if the application is running in CLI\n */\n public runningInConsole (): boolean {\n return typeof process !== 'undefined'\n && !!process.stdout\n && !!process.stdin\n\n }\n\n public getRuntimeEnv (): 'browser' | 'node' | 'unknown' {\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n return 'browser'\n }\n if (typeof process !== 'undefined' && process.versions?.node) {\n return 'node'\n }\n return 'unknown'\n }\n\n /**\n * Boot all service providers after registration\n */\n public async boot () {\n if (this.booted) return\n\n for (const provider of this.providers) {\n if (provider.boot) {\n if (Container.hasAnyDecorator(provider.boot)) {\n /**\n * If the service provider is decorated use the IoC container\n */\n await this.make<any>(provider.boot)\n } else {\n /**\n * Otherwise instantiate manually so that we can at least\n * pass the app instance\n */\n await provider.boot(this)\n }\n }\n }\n\n this.booted = true\n }\n\n /**\n * Fire up the developement server using the user provided arguments\n * \n * Port will be auto assigned if provided one is not available\n * \n * @param h3App The current H3 app instance\n * @param preferedPort If provided, this will overide the port set in the evironment\n */\n public async fire (h3App: H3, preferedPort?: number) {\n const serve = this.make('http.serve')\n\n const port: number = preferedPort ?? env('PORT', 3000)\n const tries: number = env('RETRIES', 1)\n const hostname: string = env('HOSTNAME', 'localhost')\n\n try {\n const realPort = await detect(port)\n\n if (port == realPort) {\n const server = serve(h3App, {\n port,\n hostname,\n silent: true,\n })\n\n Logger.parse([\n ['🚀 H3ravel running at:', 'green'],\n [`${server.options.protocol ?? 'http'}://${server.options.hostname}:${server.options.port}`, 'cyan']]\n )\n } else if (this.tries <= tries) {\n await this.fire(h3App, realPort)\n this.tries++\n } else {\n Logger.parse([\n ['ERROR:', 'bgRed'],\n ['No free port available', 'red'],\n ])\n }\n } catch (e: any) {\n Logger.parse([\n ['An error occured', 'bgRed'],\n [e.message, 'red'],\n [e.stack, 'red']\n ], '\\n')\n }\n }\n\n /**\n * Attempt to dynamically import an optional module\n */\n private async safeImport (moduleName: string) {\n try {\n const mod = await import(moduleName)\n return mod.default ?? mod ?? {}\n } catch {\n return null\n }\n }\n\n /**\n * Get the base path of the app\n * \n * @returns \n */\n getBasePath (): string {\n return this.basePath\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 * @returns \n */\n getPath (name: IPathName, suffix?: string) {\n return path.join(this.paths.getPath(name, this.basePath), suffix ?? '')\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 * @returns \n */\n setPath (name: IPathName, path: string) {\n return this.paths.setPath(name, path, this.basePath)\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n getVersion (key: 'app' | 'ts') {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n}\n","import type { Argument, Command } from 'commander'\n\nimport { Application } from '../Application'\nimport { ConsoleKernel } from './ConsoleKernel'\nimport { XGeneric } from '@h3ravel/support'\n\nexport class ConsoleCommand {\n constructor(protected app: Application, protected kernel: ConsoleKernel) { }\n\n /**\n * The underlying commander instance.\n *\n * @var Command\n */\n public program!: Command\n\n /**\n * The name and signature of the console command.\n *\n * @var string\n */\n protected signature!: string\n\n /**\n * A dictionary of signatures or what not.\n *\n * @var object\n */\n protected dictionary: Record<string, any> = {}\n\n /**\n * The console command description.\n *\n * @var string\n */\n protected description?: string\n\n /**\n * The console command input.\n *\n * @var object\n */\n private input: XGeneric<{ options: Record<string, any>, arguments: Record<string, any> }> = {\n options: {},\n arguments: {},\n }\n\n /**\n * Execute the console command.\n */\n public async handle (..._args: any[]): Promise<void> { }\n\n setApplication (app: Application) {\n this.app = app\n }\n\n setInput (\n options: XGeneric,\n args: string[],\n regArgs: readonly Argument[],\n dictionary: Record<string, any>,\n program: Command,\n ) {\n this.program = program\n this.dictionary = dictionary\n this.input.options = options\n this.input.arguments = regArgs\n .map((e, i) => ({ [e.name()]: args[i] }))\n .reduce((e, x) => Object.assign(e, x), {})\n this.loadBaseFlags()\n }\n\n getSignature () {\n return this.signature\n }\n\n getDescription () {\n return this.description\n }\n\n option (key: string, def?: any) {\n return this.input.options[key] ?? def\n }\n\n options (key?: string) {\n if (key) {\n return this.input.options[key]\n }\n return this.input.options\n }\n\n argument (key: string, def?: any) {\n return this.input.arguments[key] ?? def\n }\n\n arguments () {\n return this.input.arguments\n }\n\n loadBaseFlags () {\n this.input.options.lock = this.program.getOptionValue('lock') ?? false\n this.input.options.quiet = this.program.getOptionValue('quiet') ?? false\n this.input.options.silent = this.program.getOptionValue('silent') ?? false\n this.input.options.verbose = this.program.getOptionValue('verbose') ?? 0\n }\n}\n","import { Application } from '../Application'\nimport { Logger } from '@h3ravel/shared'\nimport { XGeneric } from '@h3ravel/support'\nimport { mkdir } from 'node:fs/promises'\n\nexport class ConsoleKernel {\n public cwd!: string\n public output = typeof Logger\n public basePath: string = ''\n public modulePath!: string\n public consolePath!: string\n public modulePackage!: XGeneric<{ version: string }>\n public consolePackage!: XGeneric<{ version: string }>\n\n constructor(public app: Application) { }\n\n async ensureDirectoryExists (dir: string) {\n await mkdir(dir, { recursive: true })\n }\n}\n","import { Application } from '.'\nimport { IController } from '@h3ravel/shared'\n\n/**\n * Base controller class\n */\nexport abstract class Controller implements IController {\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n public show (..._ctx: any[]): any { return }\n public index (..._ctx: any[]): any { return }\n public store (..._ctx: any[]): any { return }\n public update (..._ctx: any[]): any { return }\n public destroy (..._ctx: any[]): any { return }\n}\n","export function Inject (...dependencies: string[]) {\n return function (target: any) {\n target.__inject__ = dependencies\n }\n}\n\n/**\n * Allows binding dependencies to both class and class methods \n * \n * @returns \n */\nexport function Injectable (): ClassDecorator & MethodDecorator {\n return (...args: any[]) => {\n if (args.length === 1) {\n void args[0] // class target\n }\n if (args.length === 3) {\n void args[0] // target\n void args[1] // propertyKey\n void args[2] // descriptor\n }\n }\n}\n\n// export function Injectable (): MethodDecorator & ClassDecorator {\n// return ((_target: any, _propertyKey?: string, descriptor?: PropertyDescriptor) => {\n// if (descriptor) {\n// const original = descriptor.value;\n// descriptor.value = async function (...args: any[]) {\n// const resolvedArgs = await Promise.all(args);\n// return original.apply(this, resolvedArgs);\n// };\n// }\n// }) as any;\n// }\n","import { HttpContext, IMiddleware } from '@h3ravel/shared'\n\nimport type { H3Event } from 'h3'\n\n/**\n * Kernel class handles middleware execution and response transformations.\n * It acts as the core middleware pipeline for HTTP requests.\n */\nexport class Kernel {\n /**\n * @param context - A factory function that converts an H3Event into an HttpContext.\n * @param middleware - An array of middleware classes that will be executed in sequence.\n */\n constructor(\n protected context: (event: H3Event) => HttpContext,\n protected middleware: IMiddleware[] = [],\n ) { }\n\n /**\n * Handles an incoming request and passes it through middleware before invoking the next handler.\n * \n * @param event - The raw H3 event object.\n * @param next - A callback function that represents the next layer (usually the controller or final handler).\n * @returns A promise resolving to the result of the request pipeline.\n */\n async handle (\n event: H3Event,\n next: (ctx: HttpContext) => Promise<unknown>\n ): Promise<unknown> {\n /**\n * Convert the raw event into a standardized HttpContext\n */\n const ctx = this.context(event)\n const { app } = ctx.request\n\n /**\n * Initialize the view handler method\n * \n * @param template \n * @param params \n * @returns \n */\n const view = async (template: string, params?: Record<string, any>) => {\n const edge = app.make('edge')\n return ctx.response.html(await edge.render(template, params))\n }\n\n /**\n * Bind the view method to the global variable space\n */\n globalThis.view = view\n\n /**\n * Dynamically bind the view renderer to the service container.\n * This allows any part of the request lifecycle to render templates using Edge.\n */\n app.bind('view', () => view)\n\n /**\n * Run middleware stack and obtain result\n */\n const result = await this.runMiddleware(ctx, () => next(ctx))\n\n /**\n * If a plain object is returned from a controller or middleware,\n * automatically set the JSON Content-Type header for the response.\n */\n if (result !== undefined && this.isPlainObject(result)) {\n event.res.headers.set('Content-Type', 'application/json; charset=UTF-8')\n }\n\n return result\n }\n\n /**\n * Sequentially runs middleware in the order they were registered.\n * \n * @param context - The standardized HttpContext.\n * @param next - Callback to execute when middleware completes.\n * @returns A promise resolving to the final handler's result.\n */\n private async runMiddleware (\n context: HttpContext,\n next: (ctx: HttpContext) => Promise<unknown>\n ) {\n let index = -1\n\n const runner = async (i: number): Promise<unknown> => {\n if (i <= index) throw new Error('next() called multiple times')\n index = i\n const middleware = this.middleware[i]\n\n if (middleware) {\n /**\n * Execute the current middleware and proceed to the next one\n */\n return middleware.handle(context, () => runner(i + 1))\n } else {\n /**\n * If no more middleware, call the final handler\n */\n return next(context)\n }\n }\n\n return runner(0)\n }\n\n /**\n * Utility function to determine if a value is a plain object or array.\n * \n * @param value - The value to check.\n * @returns True if the value is a plain object or array, otherwise false.\n */\n private isPlainObject (value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' &&\n value !== null &&\n (value.constructor === Object || value.constructor === Array)\n }\n}\n","import { Application } from './Application'\nimport { IServiceProvider } from '@h3ravel/shared'\n\nexport abstract class ServiceProvider implements IServiceProvider {\n /**\n * Sort order\n */\n\n public static order?: `before:${string}` | `after:${string}` | string | undefined\n\n /**\n * Sort priority\n */\n public static priority = 0\n\n /**\n * Indicate that this service provider only runs in console\n */\n public static console = false\n\n /**\n * List of registered console commands\n */\n public registeredCommands?: (new (app: any, kernel: any) => any)[]\n\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n /**\n * Register bindings to the container.\n * Runs before boot().\n */\n abstract register (...app: unknown[]): void | Promise<void>;\n\n /**\n * Perform post-registration booting of services.\n * Runs after all providers have been registered.\n */\n boot?(...app: unknown[]): void | Promise<void>;\n\n /**\n * An array of console commands to register.\n */\n commands (commands: (new (app: any, kernel: any) => any)[]): void {\n this.registeredCommands = commands\n }\n}\n","import 'reflect-metadata'\n\nimport { ServiceProvider } from '../ServiceProvider'\n\n/**\n * Bootstraps core services and bindings.\n * \n * Bind essential services to the container (logger, config repository).\n * Register app-level singletons.\n * Set up exception handling.\n * \n * Auto-Registered\n */\nexport class CoreServiceProvider extends ServiceProvider {\n public static priority = 999\n\n register () {\n }\n}\n","import { Edge } from 'edge.js'\nimport { ServiceProvider } from '../ServiceProvider'\n\nexport class ViewServiceProvider extends ServiceProvider {\n public static priority = 995\n\n register (): void {\n const config = this.app.make('config')\n const edge = Edge.create({\n cache: process.env.NODE_ENV === 'production'\n })\n\n edge.mount(this.app.getPath('views'))\n\n edge.global('asset', this.app.make('asset'))\n edge.global('config', config.get)\n edge.global('app', this.app)\n\n this.app.bind('edge', () => edge)\n }\n}\n"],"mappings":"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"}
package/dist/index.d.cts CHANGED
@@ -13,7 +13,7 @@ declare class Container implements IContainer {
13
13
  * @param target
14
14
  * @returns
15
15
  */
16
- static hasAnyDecorator(target: Function): boolean;
16
+ static hasAnyDecorator(target: (...prm: any[]) => any): boolean;
17
17
  /**
18
18
  * Bind a transient service to the container
19
19
  */
@@ -198,6 +198,7 @@ declare class ConsoleCommand {
198
198
  options(key?: string): any;
199
199
  argument(key: string, def?: any): any;
200
200
  arguments(): Record<string, any>;
201
+ loadBaseFlags(): void;
201
202
  }
202
203
  //#endregion
203
204
  //#region src/Contracts/ServiceProviderConstructor.d.ts
package/dist/index.d.ts CHANGED
@@ -14,7 +14,7 @@ declare class Container implements IContainer {
14
14
  * @param target
15
15
  * @returns
16
16
  */
17
- static hasAnyDecorator(target: Function): boolean;
17
+ static hasAnyDecorator(target: (...prm: any[]) => any): boolean;
18
18
  /**
19
19
  * Bind a transient service to the container
20
20
  */
@@ -199,6 +199,7 @@ declare class ConsoleCommand {
199
199
  options(key?: string): any;
200
200
  argument(key: string, def?: any): any;
201
201
  arguments(): Record<string, any>;
202
+ loadBaseFlags(): void;
202
203
  }
203
204
  //#endregion
204
205
  //#region src/Contracts/ServiceProviderConstructor.d.ts
package/dist/index.js CHANGED
@@ -88,7 +88,7 @@ var ContainerResolver = class ContainerResolver {
88
88
  /**
89
89
  * Resolve the bound dependencies
90
90
  */
91
- let args = params.filter((e) => ContainerResolver.isClass(e)).map((type) => {
91
+ const args = params.filter((e) => ContainerResolver.isClass(e)).map((type) => {
92
92
  return this.app.make(type);
93
93
  });
94
94
  return new Promise((resolve) => {
@@ -119,7 +119,7 @@ var Registerer = class Registerer {
119
119
  globalThis.database_path = (path$1) => this.databasePath(path$1);
120
120
  }
121
121
  appPath(path$1) {
122
- return this.app.getPath("base", path.join(`/${process.env.SRC_PATH ?? "src"}/`.replace(/([^:]\/)\/+/g, "$1"), "app", path$1 ?? ""));
122
+ return this.app.getPath("base", path.join(`/${process.env.DIST_DIR ?? "src"}/`.replace(/([^:]\/)\/+/g, "$1"), "app", path$1 ?? ""));
123
123
  }
124
124
  basePath(path$1) {
125
125
  return this.app.getPath("base", path$1);
@@ -308,7 +308,7 @@ var Application = class Application extends Container {
308
308
  hostname,
309
309
  silent: true
310
310
  });
311
- Logger.parse([[`🚀 H3ravel running at:`, "green"], [`${server.options.protocol ?? "http"}://${server.options.hostname}:${server.options.port}`, "cyan"]]);
311
+ Logger.parse([["🚀 H3ravel running at:", "green"], [`${server.options.protocol ?? "http"}://${server.options.hostname}:${server.options.port}`, "cyan"]]);
312
312
  } else if (this.tries <= tries) {
313
313
  await this.fire(h3App, realPort);
314
314
  this.tries++;
@@ -422,6 +422,7 @@ var ConsoleCommand = class {
422
422
  this.dictionary = dictionary;
423
423
  this.input.options = options;
424
424
  this.input.arguments = regArgs.map((e, i) => ({ [e.name()]: args[i] })).reduce((e, x) => Object.assign(e, x), {});
425
+ this.loadBaseFlags();
425
426
  }
426
427
  getSignature() {
427
428
  return this.signature;
@@ -442,6 +443,12 @@ var ConsoleCommand = class {
442
443
  arguments() {
443
444
  return this.input.arguments;
444
445
  }
446
+ loadBaseFlags() {
447
+ this.input.options.lock = this.program.getOptionValue("lock") ?? false;
448
+ this.input.options.quiet = this.program.getOptionValue("quiet") ?? false;
449
+ this.input.options.silent = this.program.getOptionValue("silent") ?? false;
450
+ this.input.options.verbose = this.program.getOptionValue("verbose") ?? 0;
451
+ }
445
452
  };
446
453
 
447
454
  //#endregion
@@ -531,13 +538,25 @@ var Kernel = class {
531
538
  const ctx = this.context(event);
532
539
  const { app } = ctx.request;
533
540
  /**
534
- * Dynamically bind the view renderer to the service container.
535
- * This allows any part of the request lifecycle to render templates using Edge.
541
+ * Initialize the view handler method
542
+ *
543
+ * @param template
544
+ * @param params
545
+ * @returns
536
546
  */
537
- app.bind("view", () => async (template, params) => {
547
+ const view = async (template, params) => {
538
548
  const edge = app.make("edge");
539
549
  return ctx.response.html(await edge.render(template, params));
540
- });
550
+ };
551
+ /**
552
+ * Bind the view method to the global variable space
553
+ */
554
+ globalThis.view = view;
555
+ /**
556
+ * Dynamically bind the view renderer to the service container.
557
+ * This allows any part of the request lifecycle to render templates using Edge.
558
+ */
559
+ app.bind("view", () => view);
541
560
  /**
542
561
  * Run middleware stack and obtain result
543
562
  */
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["dependencies: any[]","app: Application","params: any[]","args: any[]","app: Application","path","nodepath","port: number","tries: number","hostname: string","e: any","path","app: Application","kernel: ConsoleKernel","app: Application","context: (event: H3Event) => HttpContext","middleware: IMiddleware[]"],"sources":["../src/Container.ts","../src/Di/ContainerResolver.ts","../src/Registerer.ts","../src/Application.ts","../src/Console/ConsoleCommand.ts","../src/Console/ConsoleKernel.ts","../src/Controller.ts","../src/Di/Inject.ts","../src/Http/Kernel.ts","../src/ServiceProvider.ts","../src/Providers/CoreServiceProvider.ts","../src/Providers/ViewServiceProvider.ts"],"sourcesContent":["import type { Bindings, IContainer, UseKey } from '@h3ravel/shared'\n\ntype IBinding = UseKey | (new (..._args: any[]) => unknown)\n\nexport class Container implements IContainer {\n private bindings = new Map<IBinding, () => unknown>()\n private singletons = new Map<IBinding, unknown>()\n\n /**\n * Check if the target has any decorators\n * \n * @param target \n * @returns \n */\n static hasAnyDecorator (target: Function): boolean {\n if (Reflect.getMetadataKeys(target).length > 0) return true\n\n const paramLength = target.length\n\n for (let i = 0; i < paramLength; i++) {\n if (Reflect.getMetadataKeys(target, `__param_${i}`).length > 0) {\n return true\n }\n }\n\n return false\n }\n\n /**\n * Bind a transient service to the container\n */\n bind<T> (key: new (...args: any[]) => T, factory: () => T): void\n bind<T extends UseKey> (key: T, factory: () => Bindings[T]): void\n bind<T extends UseKey> (\n key: T,\n factory: () => Bindings[T] | T\n ) {\n this.bindings.set(key, factory)\n }\n\n /**\n * Bind a singleton service to the container\n */\n singleton<T extends UseKey> (\n key: T | (new (..._args: any[]) => Bindings[T]),\n factory: () => Bindings[T]\n ) {\n this.bindings.set(key, () => {\n if (!this.singletons.has(key)) {\n this.singletons.set(key, factory())\n }\n return this.singletons.get(key)!\n })\n }\n\n /**\n * Resolve a service from the container\n */\n make<T extends UseKey, X = undefined> (\n key: T | (new (..._args: any[]) => Bindings[T])\n ): X extends undefined ? Bindings[T] : X {\n /**\n * Direct factory binding\n */\n if (this.bindings.has(key)) {\n return this.bindings.get(key)!() as Bindings[T]\n }\n\n /**\n * If this is a class constructor, auto-resolve via reflection\n */\n if (typeof key === 'function') {\n return this.build(key)\n }\n\n throw new Error(\n `No binding found for key: ${typeof key === 'string' ? key : (key as any)?.name}`\n )\n }\n\n /**\n * Automatically build a class with constructor dependency injection\n */\n private build<T extends UseKey> (ClassType: new (..._args: any[]) => Bindings[T]): Bindings[T] {\n let dependencies: any[] = [];\n\n if (Array.isArray((ClassType as any).__inject__)) {\n dependencies = (ClassType as any).__inject__.map((alias: any) => {\n return this.make(alias)\n });\n } else {\n const paramTypes: any[] = Reflect.getMetadata('design:paramtypes', ClassType) || []\n dependencies = paramTypes.map((dep) => this.make(dep))\n }\n\n return new ClassType(...dependencies);\n }\n\n /**\n * Check if a service is registered\n */\n has (key: UseKey): boolean {\n return this.bindings.has(key)\n }\n}\n","import 'reflect-metadata';\n\nimport { Application } from '..';\n\nexport class ContainerResolver {\n constructor(private app: Application) { }\n\n async resolveMethodParams<I extends Record<string, any>> (instance: I, method: keyof I, _default?: any) {\n /**\n * Get param types for instance method\n */\n let params: any[] = Reflect.getMetadata('design:paramtypes', instance, String(method)) || [];\n\n /**\n * Ensure that the Application class is always available\n */\n if (params.length < 1 && _default) {\n params = [_default]\n }\n\n /**\n * Resolve the bound dependencies\n */\n let args: any[] = params.filter(e => ContainerResolver.isClass(e)).map((type: any) => {\n return this.app.make(type)\n });\n\n return new Promise<I>((resolve) => {\n resolve(instance[method](...args))\n })\n }\n\n static isClass (C: any) {\n return typeof C === \"function\" &&\n C.prototype !== undefined &&\n Object.toString.call(C).substring(0, 5) === 'class'\n }\n}\n","import { dd, dump } from '@h3ravel/support'\n\nimport { Application } from '.'\nimport nodepath from 'node:path'\n\nexport class Registerer {\n constructor(private app: Application) { }\n\n static register (app: Application) {\n const reg = new Registerer(app)\n reg.bootRegister()\n }\n\n bootRegister () {\n globalThis.dd = dd\n globalThis.dump = dump\n globalThis.app_path = (path?: string) => this.appPath(path)\n globalThis.base_path = (path?: string) => this.basePath(path)\n globalThis.public_path = (path?: string) => this.publicPath(path)\n globalThis.storage_path = (path?: string) => this.storagePath(path)\n globalThis.database_path = (path?: string) => this.databasePath(path)\n }\n\n private appPath (path?: string) {\n return this.app.getPath(\n 'base', nodepath.join(`/${process.env.SRC_PATH ?? 'src'}/`.replace(/([^:]\\/)\\/+/g, \"$1\"), 'app', path ?? '')\n )\n }\n\n private basePath (path?: string) {\n return this.app.getPath('base', path)\n }\n\n private publicPath (path?: string) {\n return this.app.getPath('public', path)\n }\n\n private storagePath (path?: string) {\n return this.app.getPath('base', nodepath.join('storage', path ?? ''))\n }\n\n private databasePath (path?: string) {\n return this.app.getPath('database', path)\n }\n}\n","import 'reflect-metadata';\n\nimport { IApplication, IPathName, IServiceProvider, Logger } from '@h3ravel/shared'\n\nimport { Container } from './Container'\nimport { ContainerResolver } from './Di/ContainerResolver';\nimport type { H3 } from 'h3'\nimport { PathLoader } from '@h3ravel/shared'\nimport { Registerer } from './Registerer'\nimport chalk from 'chalk';\nimport { detect } from 'detect-port';\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\n\ntype AServiceProvider = (new (_app: Application) => IServiceProvider) & IServiceProvider\n\nexport class Application extends Container implements IApplication {\n public paths = new PathLoader()\n private tries: number = 0\n private booted = false\n private versions = { app: '0', ts: '0' }\n private basePath: string\n\n private providers: IServiceProvider[] = []\n protected externalProviders: Array<new (_app: Application) => IServiceProvider> = []\n\n /**\n * List of registered console commands\n */\n public registeredCommands: (new (app: any, kernel: any) => any)[] = [];\n\n constructor(basePath: string) {\n super()\n\n dotenvExpand.expand(dotenv.config({ quiet: true }))\n\n this.basePath = basePath\n this.setPath('base', basePath)\n this.loadOptions()\n this.registerBaseBindings();\n Registerer.register(this)\n }\n\n /**\n * Register core bindings into the container\n */\n protected registerBaseBindings () {\n this.bind(Application, () => this)\n this.bind('path.base', () => this.basePath)\n this.bind('load.paths', () => this.paths)\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n for (const ProviderClass of providers) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n protected async loadOptions () {\n const app = await this.safeImport(this.getPath('base', 'package.json'))\n const core = await this.safeImport('../package.json')\n\n if (app && app.dependencies) {\n this.versions.app = app.dependencies['@h3ravel/core']\n }\n if (core && core.devDependencies) {\n this.versions.ts = app.devDependencies.typescript\n }\n }\n\n /**\n * Get all registered providers\n */\n public getRegisteredProviders () {\n return this.providers;\n }\n\n /**\n * Load default and optional providers dynamically\n * \n * Auto-Registration Behavior\n * \n * Minimal App: Loads only core, config, http, router by default.\n * Full-Stack App: Installs database, mail, queue, cache → they self-register via their providers.\n */\n protected async getConfiguredProviders (): Promise<Array<AServiceProvider>> {\n return [\n (await import('@h3ravel/core')).CoreServiceProvider,\n (await import('@h3ravel/core')).ViewServiceProvider,\n ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders();\n const allProviders = [...coreProviders, ...this.externalProviders];\n\n /**\n * Deduplicate by class reference\n */\n const uniqueProviders = Array.from(new Set(allProviders));\n\n return this.sortProviders(uniqueProviders);\n }\n\n private sortProviders (providers: Array<AServiceProvider>) {\n const priorityMap = new Map<string, number>();\n\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n priorityMap.set(Provider.name, (Provider as any).priority ?? 0);\n });\n\n /**\n * Handle before/after adjustments\n */\n providers.forEach((Provider) => {\n const order = (Provider as any).order;\n if (!order) return;\n\n const [direction, target] = order.split(':');\n const targetPriority = priorityMap.get(target) ?? 0;\n\n if (direction === 'before') {\n priorityMap.set(Provider.name, targetPriority - 1);\n } else if (direction === 'after') {\n priorityMap.set(Provider.name, targetPriority + 1);\n }\n });\n\n /**\n * Service providers sorted based on thier name and priority\n */\n const sorted = providers.sort(\n (A, B) => (priorityMap.get(B.name) ?? 0) - (priorityMap.get(A.name) ?? 0)\n );\n\n /**\n * If debug is enabled, let's show the loaded service provider info\n */\n if (process.env.APP_DEBUG === 'true' && process.env.EXTENDED_DEBUG !== 'false' && !sorted.some(e => e.console)) {\n console.table(\n sorted.map((P) => ({\n Provider: P.name,\n Priority: priorityMap.get(P.name),\n Order: (P as any).order || 'N/A',\n }))\n );\n\n console.info(`Set ${chalk.bgCyan(' APP_DEBUG = false ')} in your .env file to hide this information`, \"\\n\")\n }\n\n return sorted\n }\n\n registerProviders (providers: Array<AServiceProvider>): void {\n this.externalProviders.push(...providers)\n }\n\n /**\n * Register a provider\n */\n public async register (provider: IServiceProvider) {\n await new ContainerResolver(this).resolveMethodParams(provider, 'register', this)\n if (provider.registeredCommands && provider.registeredCommands.length > 0) {\n this.registeredCommands.push(...provider.registeredCommands)\n }\n this.providers.push(provider)\n }\n\n /**\n * checks if the application is running in CLI\n */\n public runningInConsole (): boolean {\n return typeof process !== 'undefined'\n && !!process.stdout\n && !!process.stdin\n\n }\n\n public getRuntimeEnv (): 'browser' | 'node' | 'unknown' {\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n return 'browser'\n }\n if (typeof process !== 'undefined' && process.versions?.node) {\n return 'node'\n }\n return 'unknown'\n }\n\n /**\n * Boot all service providers after registration\n */\n public async boot () {\n if (this.booted) return\n\n for (const provider of this.providers) {\n if (provider.boot) {\n if (Container.hasAnyDecorator(provider.boot)) {\n /**\n * If the service provider is decorated use the IoC container\n */\n await this.make<any>(provider.boot)\n } else {\n /**\n * Otherwise instantiate manually so that we can at least\n * pass the app instance\n */\n await provider.boot(this)\n }\n }\n }\n\n this.booted = true\n }\n\n /**\n * Fire up the developement server using the user provided arguments\n * \n * Port will be auto assigned if provided one is not available\n * \n * @param h3App The current H3 app instance\n * @param preferedPort If provided, this will overide the port set in the evironment\n */\n public async fire (h3App: H3, preferedPort?: number) {\n const serve = this.make('http.serve')\n\n const port: number = preferedPort ?? env('PORT', 3000)\n const tries: number = env('RETRIES', 1)\n const hostname: string = env('HOSTNAME', 'localhost')\n\n try {\n const realPort = await detect(port)\n\n if (port == realPort) {\n const server = serve(h3App, {\n port,\n hostname,\n silent: true,\n })\n\n Logger.parse([\n [`🚀 H3ravel running at:`, 'green'],\n [`${server.options.protocol ?? 'http'}://${server.options.hostname}:${server.options.port}`, 'cyan']]\n )\n } else if (this.tries <= tries) {\n await this.fire(h3App, realPort)\n this.tries++\n } else {\n Logger.parse([\n ['ERROR:', 'bgRed'],\n ['No free port available', 'red'],\n ])\n }\n } catch (e: any) {\n Logger.parse([\n ['An error occured', 'bgRed'],\n [e.message, 'red'],\n [e.stack, 'red']\n ], \"\\n\")\n }\n }\n\n /**\n * Attempt to dynamically import an optional module\n */\n private async safeImport (moduleName: string) {\n try {\n const mod = await import(moduleName)\n return mod.default ?? mod ?? {}\n } catch {\n return null\n }\n }\n\n /**\n * Get the base path of the app\n * \n * @returns \n */\n getBasePath (): string {\n return this.basePath\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 * @returns \n */\n getPath (name: IPathName, suffix?: string) {\n return path.join(this.paths.getPath(name, this.basePath), suffix ?? '')\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 * @returns \n */\n setPath (name: IPathName, path: string) {\n return this.paths.setPath(name, path, this.basePath)\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n getVersion (key: 'app' | 'ts') {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n}\n","import type { Argument, Command } from \"commander\";\n\nimport { Application } from \"../Application\";\nimport { ConsoleKernel } from \"./ConsoleKernel\";\nimport { XGeneric } from \"@h3ravel/support\";\n\nexport class ConsoleCommand {\n constructor(protected app: Application, protected kernel: ConsoleKernel) { }\n\n /**\n * The underlying commander instance.\n *\n * @var Command\n */\n public program!: Command;\n\n /**\n * The name and signature of the console command.\n *\n * @var string\n */\n protected signature!: string;\n\n /**\n * A dictionary of signatures or what not.\n *\n * @var object\n */\n protected dictionary: Record<string, any> = {}\n\n /**\n * The console command description.\n *\n * @var string\n */\n protected description?: string;\n\n /**\n * The console command input.\n *\n * @var object\n */\n private input: XGeneric<{ options: Record<string, any>, arguments: Record<string, any> }> = {\n options: {},\n arguments: {},\n }\n\n /**\n * Execute the console command.\n */\n public async handle (..._args: any[]): Promise<void> { }\n\n setApplication (app: Application) {\n this.app = app\n }\n\n setInput (\n options: XGeneric,\n args: string[],\n regArgs: readonly Argument[],\n dictionary: Record<string, any>,\n program: Command,\n ) {\n this.program = program\n this.dictionary = dictionary\n this.input.options = options\n this.input.arguments = regArgs\n .map((e, i) => ({ [e.name()]: args[i] }))\n .reduce((e, x) => Object.assign(e, x), {})\n }\n\n getSignature () {\n return this.signature\n }\n\n getDescription () {\n return this.description\n }\n\n option (key: string, def?: any) {\n return this.input.options[key] ?? def\n }\n\n options (key?: string) {\n if (key) {\n return this.input.options[key]\n }\n return this.input.options\n }\n\n argument (key: string, def?: any) {\n return this.input.arguments[key] ?? def\n }\n\n arguments () {\n return this.input.arguments\n }\n}\n","import { Application } from \"../Application\";\nimport { Logger } from \"@h3ravel/shared\";\nimport { XGeneric } from \"@h3ravel/support\";\nimport { mkdir } from \"node:fs/promises\";\n\nexport class ConsoleKernel {\n public cwd!: string\n public output = typeof Logger\n public basePath: string = ''\n public modulePath!: string\n public consolePath!: string\n public modulePackage!: XGeneric<{ version: string }>\n public consolePackage!: XGeneric<{ version: string }>\n\n constructor(public app: Application) { }\n\n async ensureDirectoryExists (dir: string) {\n await mkdir(dir, { recursive: true })\n }\n}\n","import { Application } from '.'\nimport { IController } from '@h3ravel/shared'\n\n/**\n * Base controller class\n */\nexport abstract class Controller implements IController {\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n public show (..._ctx: any[]): any { return }\n public index (..._ctx: any[]): any { return }\n public store (..._ctx: any[]): any { return }\n public update (..._ctx: any[]): any { return }\n public destroy (..._ctx: any[]): any { return }\n}\n","export function Inject (...dependencies: string[]) {\n return function (target: any) {\n target.__inject__ = dependencies;\n };\n}\n\n/**\n * Allows binding dependencies to both class and class methods \n * \n * @returns \n */\nexport function Injectable (): ClassDecorator & MethodDecorator {\n return (...args: any[]) => {\n if (args.length === 1) {\n void args[0]; // class target\n }\n if (args.length === 3) {\n void args[0]; // target\n void args[1]; // propertyKey\n void args[2]; // descriptor\n }\n };\n}\n\n// export function Injectable (): MethodDecorator & ClassDecorator {\n// return ((_target: any, _propertyKey?: string, descriptor?: PropertyDescriptor) => {\n// if (descriptor) {\n// const original = descriptor.value;\n// descriptor.value = async function (...args: any[]) {\n// const resolvedArgs = await Promise.all(args);\n// return original.apply(this, resolvedArgs);\n// };\n// }\n// }) as any;\n// }\n","import { HttpContext, IMiddleware } from '@h3ravel/shared'\n\nimport type { H3Event } from 'h3'\n\n/**\n * Kernel class handles middleware execution and response transformations.\n * It acts as the core middleware pipeline for HTTP requests.\n */\nexport class Kernel {\n /**\n * @param context - A factory function that converts an H3Event into an HttpContext.\n * @param middleware - An array of middleware classes that will be executed in sequence.\n */\n constructor(\n protected context: (event: H3Event) => HttpContext,\n protected middleware: IMiddleware[] = [],\n ) { }\n\n /**\n * Handles an incoming request and passes it through middleware before invoking the next handler.\n * \n * @param event - The raw H3 event object.\n * @param next - A callback function that represents the next layer (usually the controller or final handler).\n * @returns A promise resolving to the result of the request pipeline.\n */\n async handle (\n event: H3Event,\n next: (ctx: HttpContext) => Promise<unknown>\n ): Promise<unknown> {\n /**\n * Convert the raw event into a standardized HttpContext\n */\n const ctx = this.context(event)\n const { app } = ctx.request\n\n /**\n * Dynamically bind the view renderer to the service container.\n * This allows any part of the request lifecycle to render templates using Edge.\n */\n app.bind('view', () => async (template: string, params?: Record<string, any>) => {\n const edge = app.make('edge')\n return ctx.response.html(await edge.render(template, params))\n })\n\n /**\n * Run middleware stack and obtain result\n */\n const result = await this.runMiddleware(ctx, () => next(ctx))\n\n /**\n * If a plain object is returned from a controller or middleware,\n * automatically set the JSON Content-Type header for the response.\n */\n if (result !== undefined && this.isPlainObject(result)) {\n event.res.headers.set('Content-Type', 'application/json; charset=UTF-8')\n }\n\n return result\n }\n\n /**\n * Sequentially runs middleware in the order they were registered.\n * \n * @param context - The standardized HttpContext.\n * @param next - Callback to execute when middleware completes.\n * @returns A promise resolving to the final handler's result.\n */\n private async runMiddleware (\n context: HttpContext,\n next: (ctx: HttpContext) => Promise<unknown>\n ) {\n let index = -1\n\n const runner = async (i: number): Promise<unknown> => {\n if (i <= index) throw new Error('next() called multiple times')\n index = i\n const middleware = this.middleware[i]\n\n if (middleware) {\n /**\n * Execute the current middleware and proceed to the next one\n */\n return middleware.handle(context, () => runner(i + 1))\n } else {\n /**\n * If no more middleware, call the final handler\n */\n return next(context)\n }\n }\n\n return runner(0)\n }\n\n /**\n * Utility function to determine if a value is a plain object or array.\n * \n * @param value - The value to check.\n * @returns True if the value is a plain object or array, otherwise false.\n */\n private isPlainObject (value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' &&\n value !== null &&\n (value.constructor === Object || value.constructor === Array)\n }\n}\n","import { Application } from './Application'\nimport { IServiceProvider } from '@h3ravel/shared'\n\nexport abstract class ServiceProvider implements IServiceProvider {\n /**\n * Sort order\n */\n\n public static order?: `before:${string}` | `after:${string}` | string | undefined;\n\n /**\n * Sort priority\n */\n public static priority = 0;\n\n /**\n * Indicate that this service provider only runs in console\n */\n public static console = false;\n\n /**\n * List of registered console commands\n */\n public registeredCommands?: (new (app: any, kernel: any) => any)[];\n\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n /**\n * Register bindings to the container.\n * Runs before boot().\n */\n abstract register (...app: unknown[]): void | Promise<void>;\n\n /**\n * Perform post-registration booting of services.\n * Runs after all providers have been registered.\n */\n boot?(...app: unknown[]): void | Promise<void>;\n\n /**\n * An array of console commands to register.\n */\n commands (commands: (new (app: any, kernel: any) => any)[]): void {\n this.registeredCommands = commands\n }\n}\n","import 'reflect-metadata'\n\nimport { ServiceProvider } from '../ServiceProvider'\n\n/**\n * Bootstraps core services and bindings.\n * \n * Bind essential services to the container (logger, config repository).\n * Register app-level singletons.\n * Set up exception handling.\n * \n * Auto-Registered\n */\nexport class CoreServiceProvider extends ServiceProvider {\n public static priority = 999;\n\n register () {\n }\n}\n","import { Edge } from 'edge.js'\nimport { ServiceProvider } from '../ServiceProvider'\n\nexport class ViewServiceProvider extends ServiceProvider {\n public static priority = 995;\n\n register (): void {\n const config = this.app.make('config')\n const edge = Edge.create({\n cache: process.env.NODE_ENV === 'production'\n })\n\n edge.mount(this.app.getPath('views'))\n\n edge.global('asset', this.app.make('asset'))\n edge.global('config', config.get)\n edge.global('app', this.app)\n\n this.app.bind('edge', () => edge)\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":["dependencies: any[]","app: Application","params: any[]","args: any[]","app: Application","path","nodepath","port: number","tries: number","hostname: string","e: any","path","app: Application","kernel: ConsoleKernel","app: Application","context: (event: H3Event) => HttpContext","middleware: IMiddleware[]"],"sources":["../src/Container.ts","../src/Di/ContainerResolver.ts","../src/Registerer.ts","../src/Application.ts","../src/Console/ConsoleCommand.ts","../src/Console/ConsoleKernel.ts","../src/Controller.ts","../src/Di/Inject.ts","../src/Http/Kernel.ts","../src/ServiceProvider.ts","../src/Providers/CoreServiceProvider.ts","../src/Providers/ViewServiceProvider.ts"],"sourcesContent":["import type { Bindings, IContainer, UseKey } from '@h3ravel/shared'\n\ntype IBinding = UseKey | (new (..._args: any[]) => unknown)\n\nexport class Container implements IContainer {\n private bindings = new Map<IBinding, () => unknown>()\n private singletons = new Map<IBinding, unknown>()\n\n /**\n * Check if the target has any decorators\n * \n * @param target \n * @returns \n */\n static hasAnyDecorator (target: (...prm: any[]) => any): boolean {\n if (Reflect.getMetadataKeys(target).length > 0) return true\n\n const paramLength = target.length\n\n for (let i = 0; i < paramLength; i++) {\n if (Reflect.getMetadataKeys(target, `__param_${i}`).length > 0) {\n return true\n }\n }\n\n return false\n }\n\n /**\n * Bind a transient service to the container\n */\n bind<T> (key: new (...args: any[]) => T, factory: () => T): void\n bind<T extends UseKey> (key: T, factory: () => Bindings[T]): void\n bind<T extends UseKey> (\n key: T,\n factory: () => Bindings[T] | T\n ) {\n this.bindings.set(key, factory)\n }\n\n /**\n * Bind a singleton service to the container\n */\n singleton<T extends UseKey> (\n key: T | (new (..._args: any[]) => Bindings[T]),\n factory: () => Bindings[T]\n ) {\n this.bindings.set(key, () => {\n if (!this.singletons.has(key)) {\n this.singletons.set(key, factory())\n }\n return this.singletons.get(key)!\n })\n }\n\n /**\n * Resolve a service from the container\n */\n make<T extends UseKey, X = undefined> (\n key: T | (new (..._args: any[]) => Bindings[T])\n ): X extends undefined ? Bindings[T] : X {\n /**\n * Direct factory binding\n */\n if (this.bindings.has(key)) {\n return this.bindings.get(key)!() as Bindings[T]\n }\n\n /**\n * If this is a class constructor, auto-resolve via reflection\n */\n if (typeof key === 'function') {\n return this.build(key)\n }\n\n throw new Error(\n `No binding found for key: ${typeof key === 'string' ? key : (key as any)?.name}`\n )\n }\n\n /**\n * Automatically build a class with constructor dependency injection\n */\n private build<T extends UseKey> (ClassType: new (..._args: any[]) => Bindings[T]): Bindings[T] {\n let dependencies: any[] = []\n\n if (Array.isArray((ClassType as any).__inject__)) {\n dependencies = (ClassType as any).__inject__.map((alias: any) => {\n return this.make(alias)\n })\n } else {\n const paramTypes: any[] = Reflect.getMetadata('design:paramtypes', ClassType) || []\n dependencies = paramTypes.map((dep) => this.make(dep))\n }\n\n return new ClassType(...dependencies)\n }\n\n /**\n * Check if a service is registered\n */\n has (key: UseKey): boolean {\n return this.bindings.has(key)\n }\n}\n","import 'reflect-metadata'\n\nimport { Application } from '..'\n\nexport class ContainerResolver {\n constructor(private app: Application) { }\n\n async resolveMethodParams<I extends Record<string, any>> (instance: I, method: keyof I, _default?: any) {\n /**\n * Get param types for instance method\n */\n let params: any[] = Reflect.getMetadata('design:paramtypes', instance, String(method)) || []\n\n /**\n * Ensure that the Application class is always available\n */\n if (params.length < 1 && _default) {\n params = [_default]\n }\n\n /**\n * Resolve the bound dependencies\n */\n const args: any[] = params.filter(e => ContainerResolver.isClass(e)).map((type: any) => {\n return this.app.make(type)\n })\n\n return new Promise<I>((resolve) => {\n resolve(instance[method](...args))\n })\n }\n\n static isClass (C: any) {\n return typeof C === 'function' &&\n C.prototype !== undefined &&\n Object.toString.call(C).substring(0, 5) === 'class'\n }\n}\n","import { dd, dump } from '@h3ravel/support'\n\nimport { Application } from '.'\nimport nodepath from 'node:path'\n\nexport class Registerer {\n constructor(private app: Application) { }\n\n static register (app: Application) {\n const reg = new Registerer(app)\n reg.bootRegister()\n }\n\n bootRegister () {\n globalThis.dd = dd\n globalThis.dump = dump\n globalThis.app_path = (path?: string) => this.appPath(path)\n globalThis.base_path = (path?: string) => this.basePath(path)\n globalThis.public_path = (path?: string) => this.publicPath(path)\n globalThis.storage_path = (path?: string) => this.storagePath(path)\n globalThis.database_path = (path?: string) => this.databasePath(path)\n }\n\n private appPath (path?: string) {\n return this.app.getPath(\n 'base', nodepath.join(`/${process.env.DIST_DIR ?? 'src'}/`.replace(/([^:]\\/)\\/+/g, '$1'), 'app', path ?? '')\n )\n }\n\n private basePath (path?: string) {\n return this.app.getPath('base', path)\n }\n\n private publicPath (path?: string) {\n return this.app.getPath('public', path)\n }\n\n private storagePath (path?: string) {\n return this.app.getPath('base', nodepath.join('storage', path ?? ''))\n }\n\n private databasePath (path?: string) {\n return this.app.getPath('database', path)\n }\n}\n","import 'reflect-metadata'\n\nimport { IApplication, IPathName, IServiceProvider, Logger } from '@h3ravel/shared'\n\nimport { Container } from './Container'\nimport { ContainerResolver } from './Di/ContainerResolver'\nimport type { H3 } from 'h3'\nimport { PathLoader } from '@h3ravel/shared'\nimport { Registerer } from './Registerer'\nimport chalk from 'chalk'\nimport { detect } from 'detect-port'\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\n\ntype AServiceProvider = (new (_app: Application) => IServiceProvider) & IServiceProvider\n\nexport class Application extends Container implements IApplication {\n public paths = new PathLoader()\n private tries: number = 0\n private booted = false\n private versions = { app: '0', ts: '0' }\n private basePath: string\n\n private providers: IServiceProvider[] = []\n protected externalProviders: Array<new (_app: Application) => IServiceProvider> = []\n\n /**\n * List of registered console commands\n */\n public registeredCommands: (new (app: any, kernel: any) => any)[] = []\n\n constructor(basePath: string) {\n super()\n\n dotenvExpand.expand(dotenv.config({ quiet: true }))\n\n this.basePath = basePath\n this.setPath('base', basePath)\n this.loadOptions()\n this.registerBaseBindings()\n Registerer.register(this)\n }\n\n /**\n * Register core bindings into the container\n */\n protected registerBaseBindings () {\n this.bind(Application, () => this)\n this.bind('path.base', () => this.basePath)\n this.bind('load.paths', () => this.paths)\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n for (const ProviderClass of providers) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n protected async loadOptions () {\n const app = await this.safeImport(this.getPath('base', 'package.json'))\n const core = await this.safeImport('../package.json')\n\n if (app && app.dependencies) {\n this.versions.app = app.dependencies['@h3ravel/core']\n }\n if (core && core.devDependencies) {\n this.versions.ts = app.devDependencies.typescript\n }\n }\n\n /**\n * Get all registered providers\n */\n public getRegisteredProviders () {\n return this.providers\n }\n\n /**\n * Load default and optional providers dynamically\n * \n * Auto-Registration Behavior\n * \n * Minimal App: Loads only core, config, http, router by default.\n * Full-Stack App: Installs database, mail, queue, cache → they self-register via their providers.\n */\n protected async getConfiguredProviders (): Promise<Array<AServiceProvider>> {\n return [\n (await import('@h3ravel/core')).CoreServiceProvider,\n (await import('@h3ravel/core')).ViewServiceProvider,\n ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders()\n const allProviders = [...coreProviders, ...this.externalProviders]\n\n /**\n * Deduplicate by class reference\n */\n const uniqueProviders = Array.from(new Set(allProviders))\n\n return this.sortProviders(uniqueProviders)\n }\n\n private sortProviders (providers: Array<AServiceProvider>) {\n const priorityMap = new Map<string, number>()\n\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n priorityMap.set(Provider.name, (Provider as any).priority ?? 0)\n })\n\n /**\n * Handle before/after adjustments\n */\n providers.forEach((Provider) => {\n const order = (Provider as any).order\n if (!order) return\n\n const [direction, target] = order.split(':')\n const targetPriority = priorityMap.get(target) ?? 0\n\n if (direction === 'before') {\n priorityMap.set(Provider.name, targetPriority - 1)\n } else if (direction === 'after') {\n priorityMap.set(Provider.name, targetPriority + 1)\n }\n })\n\n /**\n * Service providers sorted based on thier name and priority\n */\n const sorted = providers.sort(\n (A, B) => (priorityMap.get(B.name) ?? 0) - (priorityMap.get(A.name) ?? 0)\n )\n\n /**\n * If debug is enabled, let's show the loaded service provider info\n */\n if (process.env.APP_DEBUG === 'true' && process.env.EXTENDED_DEBUG !== 'false' && !sorted.some(e => e.console)) {\n console.table(\n sorted.map((P) => ({\n Provider: P.name,\n Priority: priorityMap.get(P.name),\n Order: (P as any).order || 'N/A',\n }))\n )\n\n console.info(`Set ${chalk.bgCyan(' APP_DEBUG = false ')} in your .env file to hide this information`, '\\n')\n }\n\n return sorted\n }\n\n registerProviders (providers: Array<AServiceProvider>): void {\n this.externalProviders.push(...providers)\n }\n\n /**\n * Register a provider\n */\n public async register (provider: IServiceProvider) {\n await new ContainerResolver(this).resolveMethodParams(provider, 'register', this)\n if (provider.registeredCommands && provider.registeredCommands.length > 0) {\n this.registeredCommands.push(...provider.registeredCommands)\n }\n this.providers.push(provider)\n }\n\n /**\n * checks if the application is running in CLI\n */\n public runningInConsole (): boolean {\n return typeof process !== 'undefined'\n && !!process.stdout\n && !!process.stdin\n\n }\n\n public getRuntimeEnv (): 'browser' | 'node' | 'unknown' {\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n return 'browser'\n }\n if (typeof process !== 'undefined' && process.versions?.node) {\n return 'node'\n }\n return 'unknown'\n }\n\n /**\n * Boot all service providers after registration\n */\n public async boot () {\n if (this.booted) return\n\n for (const provider of this.providers) {\n if (provider.boot) {\n if (Container.hasAnyDecorator(provider.boot)) {\n /**\n * If the service provider is decorated use the IoC container\n */\n await this.make<any>(provider.boot)\n } else {\n /**\n * Otherwise instantiate manually so that we can at least\n * pass the app instance\n */\n await provider.boot(this)\n }\n }\n }\n\n this.booted = true\n }\n\n /**\n * Fire up the developement server using the user provided arguments\n * \n * Port will be auto assigned if provided one is not available\n * \n * @param h3App The current H3 app instance\n * @param preferedPort If provided, this will overide the port set in the evironment\n */\n public async fire (h3App: H3, preferedPort?: number) {\n const serve = this.make('http.serve')\n\n const port: number = preferedPort ?? env('PORT', 3000)\n const tries: number = env('RETRIES', 1)\n const hostname: string = env('HOSTNAME', 'localhost')\n\n try {\n const realPort = await detect(port)\n\n if (port == realPort) {\n const server = serve(h3App, {\n port,\n hostname,\n silent: true,\n })\n\n Logger.parse([\n ['🚀 H3ravel running at:', 'green'],\n [`${server.options.protocol ?? 'http'}://${server.options.hostname}:${server.options.port}`, 'cyan']]\n )\n } else if (this.tries <= tries) {\n await this.fire(h3App, realPort)\n this.tries++\n } else {\n Logger.parse([\n ['ERROR:', 'bgRed'],\n ['No free port available', 'red'],\n ])\n }\n } catch (e: any) {\n Logger.parse([\n ['An error occured', 'bgRed'],\n [e.message, 'red'],\n [e.stack, 'red']\n ], '\\n')\n }\n }\n\n /**\n * Attempt to dynamically import an optional module\n */\n private async safeImport (moduleName: string) {\n try {\n const mod = await import(moduleName)\n return mod.default ?? mod ?? {}\n } catch {\n return null\n }\n }\n\n /**\n * Get the base path of the app\n * \n * @returns \n */\n getBasePath (): string {\n return this.basePath\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 * @returns \n */\n getPath (name: IPathName, suffix?: string) {\n return path.join(this.paths.getPath(name, this.basePath), suffix ?? '')\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 * @returns \n */\n setPath (name: IPathName, path: string) {\n return this.paths.setPath(name, path, this.basePath)\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n getVersion (key: 'app' | 'ts') {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n}\n","import type { Argument, Command } from 'commander'\n\nimport { Application } from '../Application'\nimport { ConsoleKernel } from './ConsoleKernel'\nimport { XGeneric } from '@h3ravel/support'\n\nexport class ConsoleCommand {\n constructor(protected app: Application, protected kernel: ConsoleKernel) { }\n\n /**\n * The underlying commander instance.\n *\n * @var Command\n */\n public program!: Command\n\n /**\n * The name and signature of the console command.\n *\n * @var string\n */\n protected signature!: string\n\n /**\n * A dictionary of signatures or what not.\n *\n * @var object\n */\n protected dictionary: Record<string, any> = {}\n\n /**\n * The console command description.\n *\n * @var string\n */\n protected description?: string\n\n /**\n * The console command input.\n *\n * @var object\n */\n private input: XGeneric<{ options: Record<string, any>, arguments: Record<string, any> }> = {\n options: {},\n arguments: {},\n }\n\n /**\n * Execute the console command.\n */\n public async handle (..._args: any[]): Promise<void> { }\n\n setApplication (app: Application) {\n this.app = app\n }\n\n setInput (\n options: XGeneric,\n args: string[],\n regArgs: readonly Argument[],\n dictionary: Record<string, any>,\n program: Command,\n ) {\n this.program = program\n this.dictionary = dictionary\n this.input.options = options\n this.input.arguments = regArgs\n .map((e, i) => ({ [e.name()]: args[i] }))\n .reduce((e, x) => Object.assign(e, x), {})\n this.loadBaseFlags()\n }\n\n getSignature () {\n return this.signature\n }\n\n getDescription () {\n return this.description\n }\n\n option (key: string, def?: any) {\n return this.input.options[key] ?? def\n }\n\n options (key?: string) {\n if (key) {\n return this.input.options[key]\n }\n return this.input.options\n }\n\n argument (key: string, def?: any) {\n return this.input.arguments[key] ?? def\n }\n\n arguments () {\n return this.input.arguments\n }\n\n loadBaseFlags () {\n this.input.options.lock = this.program.getOptionValue('lock') ?? false\n this.input.options.quiet = this.program.getOptionValue('quiet') ?? false\n this.input.options.silent = this.program.getOptionValue('silent') ?? false\n this.input.options.verbose = this.program.getOptionValue('verbose') ?? 0\n }\n}\n","import { Application } from '../Application'\nimport { Logger } from '@h3ravel/shared'\nimport { XGeneric } from '@h3ravel/support'\nimport { mkdir } from 'node:fs/promises'\n\nexport class ConsoleKernel {\n public cwd!: string\n public output = typeof Logger\n public basePath: string = ''\n public modulePath!: string\n public consolePath!: string\n public modulePackage!: XGeneric<{ version: string }>\n public consolePackage!: XGeneric<{ version: string }>\n\n constructor(public app: Application) { }\n\n async ensureDirectoryExists (dir: string) {\n await mkdir(dir, { recursive: true })\n }\n}\n","import { Application } from '.'\nimport { IController } from '@h3ravel/shared'\n\n/**\n * Base controller class\n */\nexport abstract class Controller implements IController {\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n public show (..._ctx: any[]): any { return }\n public index (..._ctx: any[]): any { return }\n public store (..._ctx: any[]): any { return }\n public update (..._ctx: any[]): any { return }\n public destroy (..._ctx: any[]): any { return }\n}\n","export function Inject (...dependencies: string[]) {\n return function (target: any) {\n target.__inject__ = dependencies\n }\n}\n\n/**\n * Allows binding dependencies to both class and class methods \n * \n * @returns \n */\nexport function Injectable (): ClassDecorator & MethodDecorator {\n return (...args: any[]) => {\n if (args.length === 1) {\n void args[0] // class target\n }\n if (args.length === 3) {\n void args[0] // target\n void args[1] // propertyKey\n void args[2] // descriptor\n }\n }\n}\n\n// export function Injectable (): MethodDecorator & ClassDecorator {\n// return ((_target: any, _propertyKey?: string, descriptor?: PropertyDescriptor) => {\n// if (descriptor) {\n// const original = descriptor.value;\n// descriptor.value = async function (...args: any[]) {\n// const resolvedArgs = await Promise.all(args);\n// return original.apply(this, resolvedArgs);\n// };\n// }\n// }) as any;\n// }\n","import { HttpContext, IMiddleware } from '@h3ravel/shared'\n\nimport type { H3Event } from 'h3'\n\n/**\n * Kernel class handles middleware execution and response transformations.\n * It acts as the core middleware pipeline for HTTP requests.\n */\nexport class Kernel {\n /**\n * @param context - A factory function that converts an H3Event into an HttpContext.\n * @param middleware - An array of middleware classes that will be executed in sequence.\n */\n constructor(\n protected context: (event: H3Event) => HttpContext,\n protected middleware: IMiddleware[] = [],\n ) { }\n\n /**\n * Handles an incoming request and passes it through middleware before invoking the next handler.\n * \n * @param event - The raw H3 event object.\n * @param next - A callback function that represents the next layer (usually the controller or final handler).\n * @returns A promise resolving to the result of the request pipeline.\n */\n async handle (\n event: H3Event,\n next: (ctx: HttpContext) => Promise<unknown>\n ): Promise<unknown> {\n /**\n * Convert the raw event into a standardized HttpContext\n */\n const ctx = this.context(event)\n const { app } = ctx.request\n\n /**\n * Initialize the view handler method\n * \n * @param template \n * @param params \n * @returns \n */\n const view = async (template: string, params?: Record<string, any>) => {\n const edge = app.make('edge')\n return ctx.response.html(await edge.render(template, params))\n }\n\n /**\n * Bind the view method to the global variable space\n */\n globalThis.view = view\n\n /**\n * Dynamically bind the view renderer to the service container.\n * This allows any part of the request lifecycle to render templates using Edge.\n */\n app.bind('view', () => view)\n\n /**\n * Run middleware stack and obtain result\n */\n const result = await this.runMiddleware(ctx, () => next(ctx))\n\n /**\n * If a plain object is returned from a controller or middleware,\n * automatically set the JSON Content-Type header for the response.\n */\n if (result !== undefined && this.isPlainObject(result)) {\n event.res.headers.set('Content-Type', 'application/json; charset=UTF-8')\n }\n\n return result\n }\n\n /**\n * Sequentially runs middleware in the order they were registered.\n * \n * @param context - The standardized HttpContext.\n * @param next - Callback to execute when middleware completes.\n * @returns A promise resolving to the final handler's result.\n */\n private async runMiddleware (\n context: HttpContext,\n next: (ctx: HttpContext) => Promise<unknown>\n ) {\n let index = -1\n\n const runner = async (i: number): Promise<unknown> => {\n if (i <= index) throw new Error('next() called multiple times')\n index = i\n const middleware = this.middleware[i]\n\n if (middleware) {\n /**\n * Execute the current middleware and proceed to the next one\n */\n return middleware.handle(context, () => runner(i + 1))\n } else {\n /**\n * If no more middleware, call the final handler\n */\n return next(context)\n }\n }\n\n return runner(0)\n }\n\n /**\n * Utility function to determine if a value is a plain object or array.\n * \n * @param value - The value to check.\n * @returns True if the value is a plain object or array, otherwise false.\n */\n private isPlainObject (value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' &&\n value !== null &&\n (value.constructor === Object || value.constructor === Array)\n }\n}\n","import { Application } from './Application'\nimport { IServiceProvider } from '@h3ravel/shared'\n\nexport abstract class ServiceProvider implements IServiceProvider {\n /**\n * Sort order\n */\n\n public static order?: `before:${string}` | `after:${string}` | string | undefined\n\n /**\n * Sort priority\n */\n public static priority = 0\n\n /**\n * Indicate that this service provider only runs in console\n */\n public static console = false\n\n /**\n * List of registered console commands\n */\n public registeredCommands?: (new (app: any, kernel: any) => any)[]\n\n protected app: Application\n\n constructor(app: Application) {\n this.app = app\n }\n\n /**\n * Register bindings to the container.\n * Runs before boot().\n */\n abstract register (...app: unknown[]): void | Promise<void>;\n\n /**\n * Perform post-registration booting of services.\n * Runs after all providers have been registered.\n */\n boot?(...app: unknown[]): void | Promise<void>;\n\n /**\n * An array of console commands to register.\n */\n commands (commands: (new (app: any, kernel: any) => any)[]): void {\n this.registeredCommands = commands\n }\n}\n","import 'reflect-metadata'\n\nimport { ServiceProvider } from '../ServiceProvider'\n\n/**\n * Bootstraps core services and bindings.\n * \n * Bind essential services to the container (logger, config repository).\n * Register app-level singletons.\n * Set up exception handling.\n * \n * Auto-Registered\n */\nexport class CoreServiceProvider extends ServiceProvider {\n public static priority = 999\n\n register () {\n }\n}\n","import { Edge } from 'edge.js'\nimport { ServiceProvider } from '../ServiceProvider'\n\nexport class ViewServiceProvider extends ServiceProvider {\n public static priority = 995\n\n register (): void {\n const config = this.app.make('config')\n const edge = Edge.create({\n cache: process.env.NODE_ENV === 'production'\n })\n\n edge.mount(this.app.getPath('views'))\n\n edge.global('asset', this.app.make('asset'))\n edge.global('config', config.get)\n edge.global('app', this.app)\n\n this.app.bind('edge', () => edge)\n }\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@h3ravel/core",
3
- "version": "1.9.0",
3
+ "version": "1.9.2",
4
4
  "description": "Core application container, lifecycle management and service providers for H3ravel.",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -53,7 +53,7 @@
53
53
  "reflect-metadata": "^0.2.2",
54
54
  "srvx": "^0.8.7",
55
55
  "tslib": "^2.8.1",
56
- "@h3ravel/shared": "^0.19.0",
56
+ "@h3ravel/shared": "^0.20.1",
57
57
  "@h3ravel/support": "^0.10.0"
58
58
  },
59
59
  "devDependencies": {