@h3ravel/core 1.12.2 → 1.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -75,8 +75,8 @@ declare global {
75
75
 
76
76
  /**
77
77
  * Get the database path
78
- *
79
- * @param path
78
+ *
79
+ * @param path
80
80
  */
81
81
  function database_path (path?: string): string
82
82
  }
package/dist/index.cjs CHANGED
@@ -43,12 +43,6 @@ semver = __toESM(semver);
43
43
  var Container = class {
44
44
  bindings = /* @__PURE__ */ new Map();
45
45
  singletons = /* @__PURE__ */ new Map();
46
- /**
47
- * Check if the target has any decorators
48
- *
49
- * @param target
50
- * @returns
51
- */
52
46
  static hasAnyDecorator(target) {
53
47
  if (Reflect.getMetadataKeys(target).length > 0) return true;
54
48
  const paramLength = target.length;
@@ -67,9 +61,6 @@ var Container = class {
67
61
  return this.singletons.get(key);
68
62
  });
69
63
  }
70
- /**
71
- * Resolve a service from the container
72
- */
73
64
  make(key) {
74
65
  /**
75
66
  * Direct factory binding
@@ -354,7 +345,7 @@ var Application = class Application extends Container {
354
345
  Application.versions.ts = this.versions.ts;
355
346
  }
356
347
  if (app && app.dependencies) {
357
- const versions = Object.fromEntries(Object.entries(app.dependencies).filter(([e]) => e.includes("@h3ravel")).map(([name, ver]) => [(0, __h3ravel_support.afterLast)(name, "/"), semver.default.minVersion(ver.includes("work") ? this.versions.app : ver)?.version]));
348
+ const versions = Object.fromEntries(Object.entries(app.dependencies).filter(([e]) => e.includes("@h3ravel")).map(([name, ver]) => [__h3ravel_support.Str.afterLast(name, "/"), semver.default.minVersion(ver.includes("work") ? this.versions.app : ver)?.version]));
358
349
  Object.assign(this.versions, versions);
359
350
  Object.assign(Application.versions, versions);
360
351
  }
@@ -442,7 +433,7 @@ var Application = class Application extends Container {
442
433
  /**
443
434
  * If debug is enabled, let's show the loaded service provider info
444
435
  */
445
- if (process.env.APP_DEBUG === "true" && process.env.EXTENDED_DEBUG !== "false" && !this.providers.some((e) => e.console)) ProviderRegistry.log(this.providers);
436
+ if (process.env.APP_DEBUG === "true" && process.env.EXTENDED_DEBUG !== "false" && !this.providers.some((e) => e.runsInConsole)) ProviderRegistry.log(this.providers);
446
437
  for (const provider of this.providers) if (provider.boot) if (Container.hasAnyDecorator(provider.boot))
447
438
  /**
448
439
  * If the service provider is decorated use the IoC container
@@ -616,6 +607,48 @@ var ConsoleCommand = class {
616
607
  this.input.options.silent = this.program.getOptionValue("silent") ?? false;
617
608
  this.input.options.verbose = this.program.getOptionValue("verbose") ?? 0;
618
609
  }
610
+ /**
611
+ * Log an info message
612
+ */
613
+ info(message) {
614
+ __h3ravel_shared.Logger.info(message);
615
+ }
616
+ /**
617
+ * Log a warning message
618
+ */
619
+ warn(message) {
620
+ __h3ravel_shared.Logger.warn(message);
621
+ }
622
+ /**
623
+ * Log a line message
624
+ */
625
+ line(message) {
626
+ __h3ravel_shared.Logger.log(message, "white");
627
+ }
628
+ /**
629
+ * Log a new line
630
+ */
631
+ newLine(count = 1) {
632
+ for (let i = 0; i < count; i++) console.log("");
633
+ }
634
+ /**
635
+ * Log a success message
636
+ */
637
+ success(message) {
638
+ __h3ravel_shared.Logger.success(message);
639
+ }
640
+ /**
641
+ * Log an error message
642
+ */
643
+ error(message) {
644
+ __h3ravel_shared.Logger.error(message);
645
+ }
646
+ /**
647
+ * Log a debug message
648
+ */
649
+ debug(message) {
650
+ __h3ravel_shared.Logger.debug(message);
651
+ }
619
652
  };
620
653
 
621
654
  //#endregion
@@ -646,11 +679,6 @@ var Controller = class {
646
679
  constructor(app) {
647
680
  this.app = app;
648
681
  }
649
- show(..._ctx) {}
650
- index(..._ctx) {}
651
- store(..._ctx) {}
652
- update(..._ctx) {}
653
- destroy(..._ctx) {}
654
682
  };
655
683
 
656
684
  //#endregion
@@ -676,6 +704,22 @@ function Injectable() {
676
704
  };
677
705
  }
678
706
 
707
+ //#endregion
708
+ //#region src/Exceptions/ConfigException.ts
709
+ var ConfigException = class extends Error {
710
+ key;
711
+ constructor(key, type = "config", cause) {
712
+ const info = {
713
+ any: `${key} not configured`,
714
+ env: `${key} environment variable not configured`,
715
+ config: `${key} config not set`
716
+ };
717
+ const message = __h3ravel_shared.Logger.log([["ERROR:", "bgRed"], [info[type], "white"]], " ", false);
718
+ super(message, { cause });
719
+ this.key = key;
720
+ }
721
+ };
722
+
679
723
  //#endregion
680
724
  //#region src/Http/Kernel.ts
681
725
  /**
@@ -817,14 +861,19 @@ var ServiceProvider = class extends Inference {
817
861
  */
818
862
  var CoreServiceProvider = class extends ServiceProvider {
819
863
  static priority = 999;
820
- register() {}
864
+ register() {
865
+ Object.assign(globalThis, { str: __h3ravel_support.str });
866
+ }
821
867
  boot() {
822
- globalThis.asset = this.app.make("asset");
868
+ try {
869
+ Object.assign(globalThis, { asset: this.app.make("asset") });
870
+ } catch {}
823
871
  }
824
872
  };
825
873
 
826
874
  //#endregion
827
875
  exports.Application = Application;
876
+ exports.ConfigException = ConfigException;
828
877
  exports.ConsoleCommand = ConsoleCommand;
829
878
  exports.ConsoleKernel = ConsoleKernel;
830
879
  exports.Container = Container;
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":["dependencies: any[]","app: Application","params: any[]","args: any[]","app: Application","dd","dump","path","nodepath","PathLoader","FileSystem","path","port: number","tries: number","hostname: string","e: any","app: Application","kernel: ConsoleKernel","Logger","app: Application","context: (event: H3Event) => HttpContext","middleware: IMiddleware[]"],"sources":["../src/Container.ts","../src/Di/ContainerResolver.ts","../src/ProviderRegistry.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"],"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 type { Application } from './Application'\nimport { ContainerResolver } from '../src/Di/ContainerResolver'\nimport { ServiceProvider } from './ServiceProvider'\n\ntype ProviderCtor = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\n\nexport class ProviderRegistry {\n private static providers = new Map<string, ProviderCtor>()\n private static priorityMap = new Map<string, number>()\n private static filteredProviders: string[] = []\n\n /**\n * Get a unique identifier for the Provider.\n * \n * @param provider \n * @returns \n */\n private static getKey (provider: ProviderCtor): string {\n // If provider has a declared static uid/id → prefer that\n const anyProvider = provider as any\n if (typeof anyProvider.uid === 'string') {\n return anyProvider.uid\n }\n if (typeof anyProvider.id === 'string') {\n return anyProvider.id\n }\n\n // Otherwise fallback to class name + source file (if available)\n // Works for both Node.js (filename from stack) and bundlers\n return provider.name || 'AnonymousProvider'\n }\n\n /**\n * Register one or more providers.\n * Duplicate constructors will be ignored.\n * \n * @param providers \n * @returns \n */\n static register (...providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Bulk register providers from an array.\n * \n * @param providers \n * @returns \n */\n static registerMany (providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static setFiltered (filtered: string[]): void {\n this.filteredProviders = filtered\n }\n\n /**\n * Resolve (instantiate) all providers with the given application or Service Container.\n * \n * @param app \n * @returns \n */\n static async resolve (app: Application, useServiceContainer: boolean = false): Promise<ServiceProvider[]> {\n\n // Remove all filtered service providers \n const providers = Array.from(this.providers.values()).filter(e => {\n return !!e && (this.filteredProviders.length < 1 || !this.filteredProviders.includes(e.name))\n })\n\n return await Promise.all(providers.map(async (ProviderClass) => {\n // Don't bind to the service container if we don't have to\n const provider = new ProviderClass(app)\n if (!useServiceContainer) return Promise.resolve(provider)\n\n // Bind to the service container\n await new ContainerResolver(app).resolveMethodParams(provider, 'register', app)\n return provider\n }))\n }\n\n /**\n * Sort the service providers\n * \n * @param providers \n * @returns \n */\n static sort (providers: ProviderCtor[]) {\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n const key = this.getKey(Provider)\n this.priorityMap.set(`${Provider.name}::${key}`, (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 = this.priorityMap.get(target) ?? 0\n const key = this.getKey(Provider)\n\n if (direction === 'before') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority - 1)\n } else if (direction === 'after') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority + 1)\n }\n })\n\n /**\n * Return service providers sorted based on thier name and priority\n */\n return providers.sort(\n (A, B) => {\n const keyA = this.getKey(A)\n const keyB = this.getKey(B)\n return (this.priorityMap.get(`${B.name}::${keyB}`) ?? 0) - (this.priorityMap.get(`${A.name}::${keyA}`) ?? 0)\n }\n )\n }\n\n /**\n * Log the service providers in a table\n * \n * @param priorityMap \n */\n static log<P extends ServiceProvider> (providers?: Array<P> | Map<string, P>) {\n const sorted = Array.from(((providers as unknown as P[]) ?? this.providers).values())\n\n console.table(\n sorted.map((P: any) => ({\n Name: P.constructor.name,\n Order: P.constructor.order ?? 'N/A',\n Priority: P.constructor.priority,\n }))\n )\n\n console.info('')\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static all (): ProviderCtor[] {\n return Array.from(this.providers.values())\n }\n\n /**\n * Check if a provider is already registered.\n * \n * @param provider \n * @returns \n */\n static has (provider: ProviderCtor): boolean {\n return this.providers.has(this.getKey(provider))\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 { FileSystem, IApplication, IPathName, 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 { ProviderRegistry } from './ProviderRegistry'\nimport { Registerer } from './Registerer'\nimport { ServiceProvider } from './ServiceProvider'\nimport { afterLast } from '@h3ravel/support'\nimport { detect } from 'detect-port'\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\nimport { readFile } from 'node:fs/promises'\nimport semver from 'semver'\n\ntype AServiceProvider = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\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: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private static versions: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private basePath: string\n\n private providers: ServiceProvider[] = []\n protected externalProviders: Array<AServiceProvider> = []\n protected filteredProviders: Array<string> = []\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 protected async loadOptions () {\n try {\n const corePath = FileSystem.findModulePkg('@h3ravel/core', process.cwd()) ?? ''\n const app = JSON.parse(await readFile(path.join(process.cwd(), '/package.json'), { encoding: 'utf8' }))\n const core = JSON.parse(await readFile(path.join(corePath, 'package.json'), { encoding: 'utf8' }))\n\n if (core) {\n this.versions.app = semver.minVersion(core.version)?.version ?? this.versions.app\n Application.versions.app = this.versions.app\n }\n if (app && app.devDependencies) {\n this.versions.ts = semver.minVersion(app.devDependencies.typescript)?.version ?? this.versions.ts\n Application.versions.ts = this.versions.ts\n }\n if (app && app.dependencies) {\n const versions = Object.fromEntries(Object.entries(app.dependencies)\n .filter(([e]) => e.includes('@h3ravel'))\n .map(([name, ver]: [string, any]) => [\n afterLast(name, '/'),\n semver.minVersion(ver.includes('work') ? this.versions.app : ver)?.version\n ]))\n\n Object.assign(this.versions, versions)\n Object.assign(Application.versions, versions)\n }\n } catch { /** */ }\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 ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders()\n return [...coreProviders, ...this.externalProviders]\n }\n\n /**\n * Configure and Dynamically register all configured service providers, then boot the app.\n * \n * @param providers All regitererable service providers\n * @param filtered A list of service provider name strings we do not want to register at all cost\n * @returns \n */\n public async quickStartup (providers: Array<AServiceProvider>, filtered: string[] = []) {\n this.registerProviders(providers, filtered)\n await this.registerConfiguredProviders()\n return this.boot()\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n ProviderRegistry.setFiltered(this.filteredProviders)\n ProviderRegistry.registerMany(providers)\n\n for (const ProviderClass of ProviderRegistry.all()) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n /**\n * Register service providers\n * \n * @param providers \n * @param filtered \n */\n registerProviders (providers: Array<AServiceProvider>, filtered: string[] = []): void {\n this.externalProviders.push(...providers)\n this.filteredProviders = filtered\n }\n\n /**\n * Register a provider\n */\n public async register (provider: ServiceProvider) {\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\n if (this.booted) return\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' && !this.providers.some(e => e.console)) {\n ProviderRegistry.log(this.providers)\n }\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 * 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: string) {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n static getVersion (key: string) {\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 const option = this.input.options[key] ?? def\n return option === 'null' || option === 'undefined' ? undefined : option\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\n const { app } = ctx.request\n\n /** \n * Bind HTTP Response instance to the service container\n */\n app.bind('http.response', () => {\n return ctx.response\n })\n\n /** \n * Bind HTTP Request instance to the service container\n */\n app.bind('http.request', () => {\n return ctx.request\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\nconst Inference = class { } as { new(): IServiceProvider }\n\nexport abstract class ServiceProvider extends Inference {\n /**\n * The current app instance\n */\n protected app: Application\n\n /**\n * Unique Identifier for the service providers\n */\n public static uid?: number\n\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 constructor(app: Application) {\n super()\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 boot (): void | Promise<void> {\n globalThis.asset = this.app.make('asset')\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","FileSystem","path","Str","port: number","tries: number","hostname: string","e: any","app: Application","kernel: ConsoleKernel","Logger","app: Application","Logger","context: (event: H3Event) => HttpContext","middleware: IMiddleware[]"],"sources":["../src/Container.ts","../src/Di/ContainerResolver.ts","../src/ProviderRegistry.ts","../src/Registerer.ts","../src/Application.ts","../src/Console/ConsoleCommand.ts","../src/Console/ConsoleKernel.ts","../src/Controller.ts","../src/Di/Inject.ts","../src/Exceptions/ConfigException.ts","../src/Http/Kernel.ts","../src/ServiceProvider.ts","../src/Providers/CoreServiceProvider.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<C extends abstract new (...args: any[]) => any> (target: C): boolean\n static hasAnyDecorator<F extends (...args: any[]) => any> (target: F): boolean\n static hasAnyDecorator (target: (...args: 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> (key: T): Bindings[T]\n make<C extends abstract new (...args: any[]) => any> (key: C): InstanceType<C>\n make<F extends (...args: any[]) => any> (key: F): ReturnType<F>\n make (key: any): any {\n /**\n * Direct factory binding\n */\n if (this.bindings.has(key)) {\n return this.bindings.get(key)!()\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 type { Application } from './Application'\nimport { ContainerResolver } from '../src/Di/ContainerResolver'\nimport { ServiceProvider } from './ServiceProvider'\n\ntype ProviderCtor = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\n\nexport class ProviderRegistry {\n private static providers = new Map<string, ProviderCtor>()\n private static priorityMap = new Map<string, number>()\n private static filteredProviders: string[] = []\n\n /**\n * Get a unique identifier for the Provider.\n * \n * @param provider \n * @returns \n */\n private static getKey (provider: ProviderCtor): string {\n // If provider has a declared static uid/id → prefer that\n const anyProvider = provider as any\n if (typeof anyProvider.uid === 'string') {\n return anyProvider.uid\n }\n if (typeof anyProvider.id === 'string') {\n return anyProvider.id\n }\n\n // Otherwise fallback to class name + source file (if available)\n // Works for both Node.js (filename from stack) and bundlers\n return provider.name || 'AnonymousProvider'\n }\n\n /**\n * Register one or more providers.\n * Duplicate constructors will be ignored.\n * \n * @param providers \n * @returns \n */\n static register (...providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Bulk register providers from an array.\n * \n * @param providers \n * @returns \n */\n static registerMany (providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static setFiltered (filtered: string[]): void {\n this.filteredProviders = filtered\n }\n\n /**\n * Resolve (instantiate) all providers with the given application or Service Container.\n * \n * @param app \n * @returns \n */\n static async resolve (app: Application, useServiceContainer: boolean = false): Promise<ServiceProvider[]> {\n\n // Remove all filtered service providers \n const providers = Array.from(this.providers.values()).filter(e => {\n return !!e && (this.filteredProviders.length < 1 || !this.filteredProviders.includes(e.name))\n })\n\n return await Promise.all(providers.map(async (ProviderClass) => {\n // Don't bind to the service container if we don't have to\n const provider = new ProviderClass(app)\n if (!useServiceContainer) return Promise.resolve(provider)\n\n // Bind to the service container\n await new ContainerResolver(app).resolveMethodParams(provider, 'register', app)\n return provider\n }))\n }\n\n /**\n * Sort the service providers\n * \n * @param providers \n * @returns \n */\n static sort (providers: ProviderCtor[]) {\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n const key = this.getKey(Provider)\n this.priorityMap.set(`${Provider.name}::${key}`, (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 = this.priorityMap.get(target) ?? 0\n const key = this.getKey(Provider)\n\n if (direction === 'before') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority - 1)\n } else if (direction === 'after') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority + 1)\n }\n })\n\n /**\n * Return service providers sorted based on thier name and priority\n */\n return providers.sort(\n (A, B) => {\n const keyA = this.getKey(A)\n const keyB = this.getKey(B)\n return (this.priorityMap.get(`${B.name}::${keyB}`) ?? 0) - (this.priorityMap.get(`${A.name}::${keyA}`) ?? 0)\n }\n )\n }\n\n /**\n * Log the service providers in a table\n * \n * @param priorityMap \n */\n static log<P extends ServiceProvider> (providers?: Array<P> | Map<string, P>) {\n const sorted = Array.from(((providers as unknown as P[]) ?? this.providers).values())\n\n console.table(\n sorted.map((P: any) => ({\n Name: P.constructor.name,\n Order: P.constructor.order ?? 'N/A',\n Priority: P.constructor.priority,\n }))\n )\n\n console.info('')\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static all (): ProviderCtor[] {\n return Array.from(this.providers.values())\n }\n\n /**\n * Check if a provider is already registered.\n * \n * @param provider \n * @returns \n */\n static has (provider: ProviderCtor): boolean {\n return this.providers.has(this.getKey(provider))\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 { FileSystem, IApplication, IPathName, 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 { ProviderRegistry } from './ProviderRegistry'\nimport { Registerer } from './Registerer'\nimport { ServiceProvider } from './ServiceProvider'\nimport { Str } from '@h3ravel/support'\nimport { detect } from 'detect-port'\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\nimport { readFile } from 'node:fs/promises'\nimport semver from 'semver'\n\ntype AServiceProvider = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\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: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private static versions: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private basePath: string\n\n private providers: ServiceProvider[] = []\n protected externalProviders: Array<AServiceProvider> = []\n protected filteredProviders: Array<string> = []\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 protected async loadOptions () {\n try {\n const corePath = FileSystem.findModulePkg('@h3ravel/core', process.cwd()) ?? ''\n const app = JSON.parse(await readFile(path.join(process.cwd(), '/package.json'), { encoding: 'utf8' }))\n const core = JSON.parse(await readFile(path.join(corePath, 'package.json'), { encoding: 'utf8' }))\n\n if (core) {\n this.versions.app = semver.minVersion(core.version)?.version ?? this.versions.app\n Application.versions.app = this.versions.app\n }\n if (app && app.devDependencies) {\n this.versions.ts = semver.minVersion(app.devDependencies.typescript)?.version ?? this.versions.ts\n Application.versions.ts = this.versions.ts\n }\n if (app && app.dependencies) {\n const versions = Object.fromEntries(Object.entries(app.dependencies)\n .filter(([e]) => e.includes('@h3ravel'))\n .map(([name, ver]: [string, any]) => [\n Str.afterLast(name, '/'),\n semver.minVersion(ver.includes('work') ? this.versions.app : ver)?.version\n ]))\n\n Object.assign(this.versions, versions)\n Object.assign(Application.versions, versions)\n }\n } catch { /** */ }\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 ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders()\n return [...coreProviders, ...this.externalProviders]\n }\n\n /**\n * Configure and Dynamically register all configured service providers, then boot the app.\n * \n * @param providers All regitererable service providers\n * @param filtered A list of service provider name strings we do not want to register at all cost\n * @returns \n */\n public async quickStartup (providers: Array<AServiceProvider>, filtered: string[] = []) {\n this.registerProviders(providers, filtered)\n await this.registerConfiguredProviders()\n return this.boot()\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n ProviderRegistry.setFiltered(this.filteredProviders)\n ProviderRegistry.registerMany(providers)\n\n for (const ProviderClass of ProviderRegistry.all()) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n /**\n * Register service providers\n * \n * @param providers \n * @param filtered \n */\n registerProviders (providers: Array<AServiceProvider>, filtered: string[] = []): void {\n this.externalProviders.push(...providers)\n this.filteredProviders = filtered\n }\n\n /**\n * Register a provider\n */\n public async register (provider: ServiceProvider) {\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\n if (this.booted) return\n\n /**\n * If debug is enabled, let's show the loaded service provider info\n */\n if (\n process.env.APP_DEBUG === 'true' &&\n process.env.EXTENDED_DEBUG !== 'false' &&\n !this.providers.some(e => e.runsInConsole)\n ) {\n ProviderRegistry.log(this.providers)\n }\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 * 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: string) {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n static getVersion (key: string) {\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 { Logger } from '@h3ravel/shared'\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 const option = this.input.options[key] ?? def\n return option === 'null' || option === 'undefined' ? undefined : option\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 /**\n * Log an info message\n */\n info (message: string): void {\n Logger.info(message)\n }\n\n /**\n * Log a warning message\n */\n warn (message: string): void {\n Logger.warn(message)\n }\n\n /**\n * Log a line message\n */\n line (message: string): void {\n Logger.log(message, 'white')\n }\n\n /**\n * Log a new line\n */\n newLine (count: number = 1): void {\n for (let i = 0; i < count; i++) {\n console.log('')\n }\n }\n\n /**\n * Log a success message\n */\n success (message: string): void {\n Logger.success(message)\n }\n\n /**\n * Log an error message\n */\n error (message: string): void {\n Logger.error(message)\n }\n\n /**\n * Log a debug message\n */\n debug (message: string | string[]): void {\n Logger.debug(message)\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\n public index?(..._ctx: any[]): any\n public store?(..._ctx: any[]): any\n public update?(..._ctx: any[]): any\n public destroy?(..._ctx: any[]): any\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 { Logger } from '@h3ravel/shared'\n\nexport class ConfigException extends Error {\n key: string\n\n constructor(key: string, type: 'any' | 'config' | 'env' = 'config', cause?: unknown) {\n const info = {\n any: `${key} not configured`,\n env: `${key} environment variable not configured`,\n config: `${key} config not set`,\n }\n\n const message = Logger.log([['ERROR:', 'bgRed'], [info[type], 'white']], ' ', false)\n\n super(message, {\n cause\n })\n\n this.key = key\n }\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\n const { app } = ctx.request\n\n /** \n * Bind HTTP Response instance to the service container\n */\n app.bind('http.response', () => {\n return ctx.response\n })\n\n /** \n * Bind HTTP Request instance to the service container\n */\n app.bind('http.request', () => {\n return ctx.request\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\nconst Inference = class { } as { new(): IServiceProvider }\n\nexport abstract class ServiceProvider extends Inference {\n /**\n * The current app instance\n */\n protected app: Application\n\n /**\n * Unique Identifier for the service providers\n */\n public static uid?: number\n\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 constructor(app: Application) {\n super()\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'\nimport { str } from '@h3ravel/support'\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 Object.assign(globalThis, {\n str,\n })\n }\n\n boot (): void | Promise<void> {\n try {\n Object.assign(globalThis, {\n asset: this.app.make('asset'),\n })\n } catch {/** */ }\n }\n}\n"],"mappings":"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"}
package/dist/index.d.cts CHANGED
@@ -14,7 +14,8 @@ declare class Container implements IContainer {
14
14
  * @param target
15
15
  * @returns
16
16
  */
17
- static hasAnyDecorator(target: (...prm: any[]) => any): boolean;
17
+ static hasAnyDecorator<C extends abstract new (...args: any[]) => any>(target: C): boolean;
18
+ static hasAnyDecorator<F extends (...args: any[]) => any>(target: F): boolean;
18
19
  /**
19
20
  * Bind a transient service to the container
20
21
  */
@@ -27,7 +28,9 @@ declare class Container implements IContainer {
27
28
  /**
28
29
  * Resolve a service from the container
29
30
  */
30
- make<T extends UseKey, X = undefined>(key: T | (new (..._args: any[]) => Bindings[T])): X extends undefined ? Bindings[T] : X;
31
+ make<T extends UseKey>(key: T): Bindings[T];
32
+ make<C extends abstract new (...args: any[]) => any>(key: C): InstanceType<C>;
33
+ make<F extends (...args: any[]) => any>(key: F): ReturnType<F>;
31
34
  /**
32
35
  * Automatically build a class with constructor dependency injection
33
36
  */
@@ -263,6 +266,34 @@ declare class ConsoleCommand {
263
266
  argument(key: string, def?: any): any;
264
267
  arguments(): Record<string, any>;
265
268
  loadBaseFlags(): void;
269
+ /**
270
+ * Log an info message
271
+ */
272
+ info(message: string): void;
273
+ /**
274
+ * Log a warning message
275
+ */
276
+ warn(message: string): void;
277
+ /**
278
+ * Log a line message
279
+ */
280
+ line(message: string): void;
281
+ /**
282
+ * Log a new line
283
+ */
284
+ newLine(count?: number): void;
285
+ /**
286
+ * Log a success message
287
+ */
288
+ success(message: string): void;
289
+ /**
290
+ * Log an error message
291
+ */
292
+ error(message: string): void;
293
+ /**
294
+ * Log a debug message
295
+ */
296
+ debug(message: string | string[]): void;
266
297
  }
267
298
  //#endregion
268
299
  //#region src/Contracts/ServiceProviderConstructor.d.ts
@@ -275,11 +306,11 @@ type ServiceProviderConstructor = (new (app: Application) => ServiceProvider) &
275
306
  declare abstract class Controller implements IController {
276
307
  protected app: Application;
277
308
  constructor(app: Application);
278
- show(..._ctx: any[]): any;
279
- index(..._ctx: any[]): any;
280
- store(..._ctx: any[]): any;
281
- update(..._ctx: any[]): any;
282
- destroy(..._ctx: any[]): any;
309
+ show?(..._ctx: any[]): any;
310
+ index?(..._ctx: any[]): any;
311
+ store?(..._ctx: any[]): any;
312
+ update?(..._ctx: any[]): any;
313
+ destroy?(..._ctx: any[]): any;
283
314
  }
284
315
  //#endregion
285
316
  //#region src/Di/ContainerResolver.d.ts
@@ -299,6 +330,12 @@ declare function Inject(...dependencies: string[]): (target: any) => void;
299
330
  */
300
331
  declare function Injectable(): ClassDecorator & MethodDecorator;
301
332
  //#endregion
333
+ //#region src/Exceptions/ConfigException.d.ts
334
+ declare class ConfigException extends Error {
335
+ key: string;
336
+ constructor(key: string, type?: 'any' | 'config' | 'env', cause?: unknown);
337
+ }
338
+ //#endregion
302
339
  //#region src/Http/Kernel.d.ts
303
340
  /**
304
341
  * Kernel class handles middleware execution and response transformations.
@@ -435,5 +472,5 @@ declare class Registerer {
435
472
  private databasePath;
436
473
  }
437
474
  //#endregion
438
- export { Application, ConsoleCommand, ConsoleKernel, Container, ContainerResolver, Controller, CoreServiceProvider, Inject, Injectable, Kernel, ProviderRegistry, Registerer, ServiceProvider, ServiceProviderConstructor };
475
+ export { Application, ConfigException, ConsoleCommand, ConsoleKernel, Container, ContainerResolver, Controller, CoreServiceProvider, Inject, Injectable, Kernel, ProviderRegistry, Registerer, ServiceProvider, ServiceProviderConstructor };
439
476
  //# sourceMappingURL=index.d.cts.map
package/dist/index.d.ts CHANGED
@@ -15,7 +15,8 @@ declare class Container implements IContainer {
15
15
  * @param target
16
16
  * @returns
17
17
  */
18
- static hasAnyDecorator(target: (...prm: any[]) => any): boolean;
18
+ static hasAnyDecorator<C extends abstract new (...args: any[]) => any>(target: C): boolean;
19
+ static hasAnyDecorator<F extends (...args: any[]) => any>(target: F): boolean;
19
20
  /**
20
21
  * Bind a transient service to the container
21
22
  */
@@ -28,7 +29,9 @@ declare class Container implements IContainer {
28
29
  /**
29
30
  * Resolve a service from the container
30
31
  */
31
- make<T extends UseKey, X = undefined>(key: T | (new (..._args: any[]) => Bindings[T])): X extends undefined ? Bindings[T] : X;
32
+ make<T extends UseKey>(key: T): Bindings[T];
33
+ make<C extends abstract new (...args: any[]) => any>(key: C): InstanceType<C>;
34
+ make<F extends (...args: any[]) => any>(key: F): ReturnType<F>;
32
35
  /**
33
36
  * Automatically build a class with constructor dependency injection
34
37
  */
@@ -264,6 +267,34 @@ declare class ConsoleCommand {
264
267
  argument(key: string, def?: any): any;
265
268
  arguments(): Record<string, any>;
266
269
  loadBaseFlags(): void;
270
+ /**
271
+ * Log an info message
272
+ */
273
+ info(message: string): void;
274
+ /**
275
+ * Log a warning message
276
+ */
277
+ warn(message: string): void;
278
+ /**
279
+ * Log a line message
280
+ */
281
+ line(message: string): void;
282
+ /**
283
+ * Log a new line
284
+ */
285
+ newLine(count?: number): void;
286
+ /**
287
+ * Log a success message
288
+ */
289
+ success(message: string): void;
290
+ /**
291
+ * Log an error message
292
+ */
293
+ error(message: string): void;
294
+ /**
295
+ * Log a debug message
296
+ */
297
+ debug(message: string | string[]): void;
267
298
  }
268
299
  //#endregion
269
300
  //#region src/Contracts/ServiceProviderConstructor.d.ts
@@ -276,11 +307,11 @@ type ServiceProviderConstructor = (new (app: Application) => ServiceProvider) &
276
307
  declare abstract class Controller implements IController {
277
308
  protected app: Application;
278
309
  constructor(app: Application);
279
- show(..._ctx: any[]): any;
280
- index(..._ctx: any[]): any;
281
- store(..._ctx: any[]): any;
282
- update(..._ctx: any[]): any;
283
- destroy(..._ctx: any[]): any;
310
+ show?(..._ctx: any[]): any;
311
+ index?(..._ctx: any[]): any;
312
+ store?(..._ctx: any[]): any;
313
+ update?(..._ctx: any[]): any;
314
+ destroy?(..._ctx: any[]): any;
284
315
  }
285
316
  //#endregion
286
317
  //#region src/Di/ContainerResolver.d.ts
@@ -300,6 +331,12 @@ declare function Inject(...dependencies: string[]): (target: any) => void;
300
331
  */
301
332
  declare function Injectable(): ClassDecorator & MethodDecorator;
302
333
  //#endregion
334
+ //#region src/Exceptions/ConfigException.d.ts
335
+ declare class ConfigException extends Error {
336
+ key: string;
337
+ constructor(key: string, type?: 'any' | 'config' | 'env', cause?: unknown);
338
+ }
339
+ //#endregion
303
340
  //#region src/Http/Kernel.d.ts
304
341
  /**
305
342
  * Kernel class handles middleware execution and response transformations.
@@ -436,5 +473,5 @@ declare class Registerer {
436
473
  private databasePath;
437
474
  }
438
475
  //#endregion
439
- export { Application, ConsoleCommand, ConsoleKernel, Container, ContainerResolver, Controller, CoreServiceProvider, Inject, Injectable, Kernel, ProviderRegistry, Registerer, ServiceProvider, ServiceProviderConstructor };
476
+ export { Application, ConfigException, ConsoleCommand, ConsoleKernel, Container, ContainerResolver, Controller, CoreServiceProvider, Inject, Injectable, Kernel, ProviderRegistry, Registerer, ServiceProvider, ServiceProviderConstructor };
440
477
  //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import "reflect-metadata";
2
2
  import { FileSystem, Logger, PathLoader } from "@h3ravel/shared";
3
- import { afterLast, dd, dump } from "@h3ravel/support";
3
+ import { Str, dd, dump, str } from "@h3ravel/support";
4
4
  import path from "node:path";
5
5
  import { detect } from "detect-port";
6
6
  import dotenv from "dotenv";
@@ -12,12 +12,6 @@ import semver from "semver";
12
12
  var Container = class {
13
13
  bindings = /* @__PURE__ */ new Map();
14
14
  singletons = /* @__PURE__ */ new Map();
15
- /**
16
- * Check if the target has any decorators
17
- *
18
- * @param target
19
- * @returns
20
- */
21
15
  static hasAnyDecorator(target) {
22
16
  if (Reflect.getMetadataKeys(target).length > 0) return true;
23
17
  const paramLength = target.length;
@@ -36,9 +30,6 @@ var Container = class {
36
30
  return this.singletons.get(key);
37
31
  });
38
32
  }
39
- /**
40
- * Resolve a service from the container
41
- */
42
33
  make(key) {
43
34
  /**
44
35
  * Direct factory binding
@@ -323,7 +314,7 @@ var Application = class Application extends Container {
323
314
  Application.versions.ts = this.versions.ts;
324
315
  }
325
316
  if (app && app.dependencies) {
326
- const versions = Object.fromEntries(Object.entries(app.dependencies).filter(([e]) => e.includes("@h3ravel")).map(([name, ver]) => [afterLast(name, "/"), semver.minVersion(ver.includes("work") ? this.versions.app : ver)?.version]));
317
+ const versions = Object.fromEntries(Object.entries(app.dependencies).filter(([e]) => e.includes("@h3ravel")).map(([name, ver]) => [Str.afterLast(name, "/"), semver.minVersion(ver.includes("work") ? this.versions.app : ver)?.version]));
327
318
  Object.assign(this.versions, versions);
328
319
  Object.assign(Application.versions, versions);
329
320
  }
@@ -411,7 +402,7 @@ var Application = class Application extends Container {
411
402
  /**
412
403
  * If debug is enabled, let's show the loaded service provider info
413
404
  */
414
- if (process.env.APP_DEBUG === "true" && process.env.EXTENDED_DEBUG !== "false" && !this.providers.some((e) => e.console)) ProviderRegistry.log(this.providers);
405
+ if (process.env.APP_DEBUG === "true" && process.env.EXTENDED_DEBUG !== "false" && !this.providers.some((e) => e.runsInConsole)) ProviderRegistry.log(this.providers);
415
406
  for (const provider of this.providers) if (provider.boot) if (Container.hasAnyDecorator(provider.boot))
416
407
  /**
417
408
  * If the service provider is decorated use the IoC container
@@ -585,6 +576,48 @@ var ConsoleCommand = class {
585
576
  this.input.options.silent = this.program.getOptionValue("silent") ?? false;
586
577
  this.input.options.verbose = this.program.getOptionValue("verbose") ?? 0;
587
578
  }
579
+ /**
580
+ * Log an info message
581
+ */
582
+ info(message) {
583
+ Logger.info(message);
584
+ }
585
+ /**
586
+ * Log a warning message
587
+ */
588
+ warn(message) {
589
+ Logger.warn(message);
590
+ }
591
+ /**
592
+ * Log a line message
593
+ */
594
+ line(message) {
595
+ Logger.log(message, "white");
596
+ }
597
+ /**
598
+ * Log a new line
599
+ */
600
+ newLine(count = 1) {
601
+ for (let i = 0; i < count; i++) console.log("");
602
+ }
603
+ /**
604
+ * Log a success message
605
+ */
606
+ success(message) {
607
+ Logger.success(message);
608
+ }
609
+ /**
610
+ * Log an error message
611
+ */
612
+ error(message) {
613
+ Logger.error(message);
614
+ }
615
+ /**
616
+ * Log a debug message
617
+ */
618
+ debug(message) {
619
+ Logger.debug(message);
620
+ }
588
621
  };
589
622
 
590
623
  //#endregion
@@ -615,11 +648,6 @@ var Controller = class {
615
648
  constructor(app) {
616
649
  this.app = app;
617
650
  }
618
- show(..._ctx) {}
619
- index(..._ctx) {}
620
- store(..._ctx) {}
621
- update(..._ctx) {}
622
- destroy(..._ctx) {}
623
651
  };
624
652
 
625
653
  //#endregion
@@ -645,6 +673,22 @@ function Injectable() {
645
673
  };
646
674
  }
647
675
 
676
+ //#endregion
677
+ //#region src/Exceptions/ConfigException.ts
678
+ var ConfigException = class extends Error {
679
+ key;
680
+ constructor(key, type = "config", cause) {
681
+ const info = {
682
+ any: `${key} not configured`,
683
+ env: `${key} environment variable not configured`,
684
+ config: `${key} config not set`
685
+ };
686
+ const message = Logger.log([["ERROR:", "bgRed"], [info[type], "white"]], " ", false);
687
+ super(message, { cause });
688
+ this.key = key;
689
+ }
690
+ };
691
+
648
692
  //#endregion
649
693
  //#region src/Http/Kernel.ts
650
694
  /**
@@ -786,12 +830,16 @@ var ServiceProvider = class extends Inference {
786
830
  */
787
831
  var CoreServiceProvider = class extends ServiceProvider {
788
832
  static priority = 999;
789
- register() {}
833
+ register() {
834
+ Object.assign(globalThis, { str });
835
+ }
790
836
  boot() {
791
- globalThis.asset = this.app.make("asset");
837
+ try {
838
+ Object.assign(globalThis, { asset: this.app.make("asset") });
839
+ } catch {}
792
840
  }
793
841
  };
794
842
 
795
843
  //#endregion
796
- export { Application, ConsoleCommand, ConsoleKernel, Container, ContainerResolver, Controller, CoreServiceProvider, Inject, Injectable, Kernel, ProviderRegistry, Registerer, ServiceProvider };
844
+ export { Application, ConfigException, ConsoleCommand, ConsoleKernel, Container, ContainerResolver, Controller, CoreServiceProvider, Inject, Injectable, Kernel, ProviderRegistry, Registerer, ServiceProvider };
797
845
  //# sourceMappingURL=index.js.map
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/ProviderRegistry.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"],"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 type { Application } from './Application'\nimport { ContainerResolver } from '../src/Di/ContainerResolver'\nimport { ServiceProvider } from './ServiceProvider'\n\ntype ProviderCtor = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\n\nexport class ProviderRegistry {\n private static providers = new Map<string, ProviderCtor>()\n private static priorityMap = new Map<string, number>()\n private static filteredProviders: string[] = []\n\n /**\n * Get a unique identifier for the Provider.\n * \n * @param provider \n * @returns \n */\n private static getKey (provider: ProviderCtor): string {\n // If provider has a declared static uid/id → prefer that\n const anyProvider = provider as any\n if (typeof anyProvider.uid === 'string') {\n return anyProvider.uid\n }\n if (typeof anyProvider.id === 'string') {\n return anyProvider.id\n }\n\n // Otherwise fallback to class name + source file (if available)\n // Works for both Node.js (filename from stack) and bundlers\n return provider.name || 'AnonymousProvider'\n }\n\n /**\n * Register one or more providers.\n * Duplicate constructors will be ignored.\n * \n * @param providers \n * @returns \n */\n static register (...providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Bulk register providers from an array.\n * \n * @param providers \n * @returns \n */\n static registerMany (providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static setFiltered (filtered: string[]): void {\n this.filteredProviders = filtered\n }\n\n /**\n * Resolve (instantiate) all providers with the given application or Service Container.\n * \n * @param app \n * @returns \n */\n static async resolve (app: Application, useServiceContainer: boolean = false): Promise<ServiceProvider[]> {\n\n // Remove all filtered service providers \n const providers = Array.from(this.providers.values()).filter(e => {\n return !!e && (this.filteredProviders.length < 1 || !this.filteredProviders.includes(e.name))\n })\n\n return await Promise.all(providers.map(async (ProviderClass) => {\n // Don't bind to the service container if we don't have to\n const provider = new ProviderClass(app)\n if (!useServiceContainer) return Promise.resolve(provider)\n\n // Bind to the service container\n await new ContainerResolver(app).resolveMethodParams(provider, 'register', app)\n return provider\n }))\n }\n\n /**\n * Sort the service providers\n * \n * @param providers \n * @returns \n */\n static sort (providers: ProviderCtor[]) {\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n const key = this.getKey(Provider)\n this.priorityMap.set(`${Provider.name}::${key}`, (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 = this.priorityMap.get(target) ?? 0\n const key = this.getKey(Provider)\n\n if (direction === 'before') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority - 1)\n } else if (direction === 'after') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority + 1)\n }\n })\n\n /**\n * Return service providers sorted based on thier name and priority\n */\n return providers.sort(\n (A, B) => {\n const keyA = this.getKey(A)\n const keyB = this.getKey(B)\n return (this.priorityMap.get(`${B.name}::${keyB}`) ?? 0) - (this.priorityMap.get(`${A.name}::${keyA}`) ?? 0)\n }\n )\n }\n\n /**\n * Log the service providers in a table\n * \n * @param priorityMap \n */\n static log<P extends ServiceProvider> (providers?: Array<P> | Map<string, P>) {\n const sorted = Array.from(((providers as unknown as P[]) ?? this.providers).values())\n\n console.table(\n sorted.map((P: any) => ({\n Name: P.constructor.name,\n Order: P.constructor.order ?? 'N/A',\n Priority: P.constructor.priority,\n }))\n )\n\n console.info('')\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static all (): ProviderCtor[] {\n return Array.from(this.providers.values())\n }\n\n /**\n * Check if a provider is already registered.\n * \n * @param provider \n * @returns \n */\n static has (provider: ProviderCtor): boolean {\n return this.providers.has(this.getKey(provider))\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 { FileSystem, IApplication, IPathName, 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 { ProviderRegistry } from './ProviderRegistry'\nimport { Registerer } from './Registerer'\nimport { ServiceProvider } from './ServiceProvider'\nimport { afterLast } from '@h3ravel/support'\nimport { detect } from 'detect-port'\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\nimport { readFile } from 'node:fs/promises'\nimport semver from 'semver'\n\ntype AServiceProvider = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\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: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private static versions: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private basePath: string\n\n private providers: ServiceProvider[] = []\n protected externalProviders: Array<AServiceProvider> = []\n protected filteredProviders: Array<string> = []\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 protected async loadOptions () {\n try {\n const corePath = FileSystem.findModulePkg('@h3ravel/core', process.cwd()) ?? ''\n const app = JSON.parse(await readFile(path.join(process.cwd(), '/package.json'), { encoding: 'utf8' }))\n const core = JSON.parse(await readFile(path.join(corePath, 'package.json'), { encoding: 'utf8' }))\n\n if (core) {\n this.versions.app = semver.minVersion(core.version)?.version ?? this.versions.app\n Application.versions.app = this.versions.app\n }\n if (app && app.devDependencies) {\n this.versions.ts = semver.minVersion(app.devDependencies.typescript)?.version ?? this.versions.ts\n Application.versions.ts = this.versions.ts\n }\n if (app && app.dependencies) {\n const versions = Object.fromEntries(Object.entries(app.dependencies)\n .filter(([e]) => e.includes('@h3ravel'))\n .map(([name, ver]: [string, any]) => [\n afterLast(name, '/'),\n semver.minVersion(ver.includes('work') ? this.versions.app : ver)?.version\n ]))\n\n Object.assign(this.versions, versions)\n Object.assign(Application.versions, versions)\n }\n } catch { /** */ }\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 ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders()\n return [...coreProviders, ...this.externalProviders]\n }\n\n /**\n * Configure and Dynamically register all configured service providers, then boot the app.\n * \n * @param providers All regitererable service providers\n * @param filtered A list of service provider name strings we do not want to register at all cost\n * @returns \n */\n public async quickStartup (providers: Array<AServiceProvider>, filtered: string[] = []) {\n this.registerProviders(providers, filtered)\n await this.registerConfiguredProviders()\n return this.boot()\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n ProviderRegistry.setFiltered(this.filteredProviders)\n ProviderRegistry.registerMany(providers)\n\n for (const ProviderClass of ProviderRegistry.all()) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n /**\n * Register service providers\n * \n * @param providers \n * @param filtered \n */\n registerProviders (providers: Array<AServiceProvider>, filtered: string[] = []): void {\n this.externalProviders.push(...providers)\n this.filteredProviders = filtered\n }\n\n /**\n * Register a provider\n */\n public async register (provider: ServiceProvider) {\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\n if (this.booted) return\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' && !this.providers.some(e => e.console)) {\n ProviderRegistry.log(this.providers)\n }\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 * 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: string) {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n static getVersion (key: string) {\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 const option = this.input.options[key] ?? def\n return option === 'null' || option === 'undefined' ? undefined : option\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\n const { app } = ctx.request\n\n /** \n * Bind HTTP Response instance to the service container\n */\n app.bind('http.response', () => {\n return ctx.response\n })\n\n /** \n * Bind HTTP Request instance to the service container\n */\n app.bind('http.request', () => {\n return ctx.request\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\nconst Inference = class { } as { new(): IServiceProvider }\n\nexport abstract class ServiceProvider extends Inference {\n /**\n * The current app instance\n */\n protected app: Application\n\n /**\n * Unique Identifier for the service providers\n */\n public static uid?: number\n\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 constructor(app: Application) {\n super()\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 boot (): void | Promise<void> {\n globalThis.asset = this.app.make('asset')\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/ProviderRegistry.ts","../src/Registerer.ts","../src/Application.ts","../src/Console/ConsoleCommand.ts","../src/Console/ConsoleKernel.ts","../src/Controller.ts","../src/Di/Inject.ts","../src/Exceptions/ConfigException.ts","../src/Http/Kernel.ts","../src/ServiceProvider.ts","../src/Providers/CoreServiceProvider.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<C extends abstract new (...args: any[]) => any> (target: C): boolean\n static hasAnyDecorator<F extends (...args: any[]) => any> (target: F): boolean\n static hasAnyDecorator (target: (...args: 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> (key: T): Bindings[T]\n make<C extends abstract new (...args: any[]) => any> (key: C): InstanceType<C>\n make<F extends (...args: any[]) => any> (key: F): ReturnType<F>\n make (key: any): any {\n /**\n * Direct factory binding\n */\n if (this.bindings.has(key)) {\n return this.bindings.get(key)!()\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 type { Application } from './Application'\nimport { ContainerResolver } from '../src/Di/ContainerResolver'\nimport { ServiceProvider } from './ServiceProvider'\n\ntype ProviderCtor = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\n\nexport class ProviderRegistry {\n private static providers = new Map<string, ProviderCtor>()\n private static priorityMap = new Map<string, number>()\n private static filteredProviders: string[] = []\n\n /**\n * Get a unique identifier for the Provider.\n * \n * @param provider \n * @returns \n */\n private static getKey (provider: ProviderCtor): string {\n // If provider has a declared static uid/id → prefer that\n const anyProvider = provider as any\n if (typeof anyProvider.uid === 'string') {\n return anyProvider.uid\n }\n if (typeof anyProvider.id === 'string') {\n return anyProvider.id\n }\n\n // Otherwise fallback to class name + source file (if available)\n // Works for both Node.js (filename from stack) and bundlers\n return provider.name || 'AnonymousProvider'\n }\n\n /**\n * Register one or more providers.\n * Duplicate constructors will be ignored.\n * \n * @param providers \n * @returns \n */\n static register (...providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Bulk register providers from an array.\n * \n * @param providers \n * @returns \n */\n static registerMany (providers: ProviderCtor[]): void {\n for (const provider of this.sort(providers.concat(...this.providers.values()))) {\n const key = this.getKey(provider)\n this.providers.set(key, provider)\n }\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static setFiltered (filtered: string[]): void {\n this.filteredProviders = filtered\n }\n\n /**\n * Resolve (instantiate) all providers with the given application or Service Container.\n * \n * @param app \n * @returns \n */\n static async resolve (app: Application, useServiceContainer: boolean = false): Promise<ServiceProvider[]> {\n\n // Remove all filtered service providers \n const providers = Array.from(this.providers.values()).filter(e => {\n return !!e && (this.filteredProviders.length < 1 || !this.filteredProviders.includes(e.name))\n })\n\n return await Promise.all(providers.map(async (ProviderClass) => {\n // Don't bind to the service container if we don't have to\n const provider = new ProviderClass(app)\n if (!useServiceContainer) return Promise.resolve(provider)\n\n // Bind to the service container\n await new ContainerResolver(app).resolveMethodParams(provider, 'register', app)\n return provider\n }))\n }\n\n /**\n * Sort the service providers\n * \n * @param providers \n * @returns \n */\n static sort (providers: ProviderCtor[]) {\n /**\n * Base priority (default 0)\n */\n providers.forEach((Provider) => {\n const key = this.getKey(Provider)\n this.priorityMap.set(`${Provider.name}::${key}`, (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 = this.priorityMap.get(target) ?? 0\n const key = this.getKey(Provider)\n\n if (direction === 'before') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority - 1)\n } else if (direction === 'after') {\n this.priorityMap.set(`${Provider.name}::${key}`, targetPriority + 1)\n }\n })\n\n /**\n * Return service providers sorted based on thier name and priority\n */\n return providers.sort(\n (A, B) => {\n const keyA = this.getKey(A)\n const keyB = this.getKey(B)\n return (this.priorityMap.get(`${B.name}::${keyB}`) ?? 0) - (this.priorityMap.get(`${A.name}::${keyA}`) ?? 0)\n }\n )\n }\n\n /**\n * Log the service providers in a table\n * \n * @param priorityMap \n */\n static log<P extends ServiceProvider> (providers?: Array<P> | Map<string, P>) {\n const sorted = Array.from(((providers as unknown as P[]) ?? this.providers).values())\n\n console.table(\n sorted.map((P: any) => ({\n Name: P.constructor.name,\n Order: P.constructor.order ?? 'N/A',\n Priority: P.constructor.priority,\n }))\n )\n\n console.info('')\n }\n\n /**\n * Get all registered providers as an array.\n * \n * @returns \n */\n static all (): ProviderCtor[] {\n return Array.from(this.providers.values())\n }\n\n /**\n * Check if a provider is already registered.\n * \n * @param provider \n * @returns \n */\n static has (provider: ProviderCtor): boolean {\n return this.providers.has(this.getKey(provider))\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 { FileSystem, IApplication, IPathName, 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 { ProviderRegistry } from './ProviderRegistry'\nimport { Registerer } from './Registerer'\nimport { ServiceProvider } from './ServiceProvider'\nimport { Str } from '@h3ravel/support'\nimport { detect } from 'detect-port'\nimport dotenv from 'dotenv'\nimport dotenvExpand from 'dotenv-expand'\nimport path from 'node:path'\nimport { readFile } from 'node:fs/promises'\nimport semver from 'semver'\n\ntype AServiceProvider = (new (_app: Application) => ServiceProvider) & Partial<ServiceProvider>\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: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private static versions: { [key: string]: string, app: string, ts: string } = { app: '0.0.0', ts: '0.0.0' }\n private basePath: string\n\n private providers: ServiceProvider[] = []\n protected externalProviders: Array<AServiceProvider> = []\n protected filteredProviders: Array<string> = []\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 protected async loadOptions () {\n try {\n const corePath = FileSystem.findModulePkg('@h3ravel/core', process.cwd()) ?? ''\n const app = JSON.parse(await readFile(path.join(process.cwd(), '/package.json'), { encoding: 'utf8' }))\n const core = JSON.parse(await readFile(path.join(corePath, 'package.json'), { encoding: 'utf8' }))\n\n if (core) {\n this.versions.app = semver.minVersion(core.version)?.version ?? this.versions.app\n Application.versions.app = this.versions.app\n }\n if (app && app.devDependencies) {\n this.versions.ts = semver.minVersion(app.devDependencies.typescript)?.version ?? this.versions.ts\n Application.versions.ts = this.versions.ts\n }\n if (app && app.dependencies) {\n const versions = Object.fromEntries(Object.entries(app.dependencies)\n .filter(([e]) => e.includes('@h3ravel'))\n .map(([name, ver]: [string, any]) => [\n Str.afterLast(name, '/'),\n semver.minVersion(ver.includes('work') ? this.versions.app : ver)?.version\n ]))\n\n Object.assign(this.versions, versions)\n Object.assign(Application.versions, versions)\n }\n } catch { /** */ }\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 ]\n }\n\n protected async getAllProviders (): Promise<Array<AServiceProvider>> {\n const coreProviders = await this.getConfiguredProviders()\n return [...coreProviders, ...this.externalProviders]\n }\n\n /**\n * Configure and Dynamically register all configured service providers, then boot the app.\n * \n * @param providers All regitererable service providers\n * @param filtered A list of service provider name strings we do not want to register at all cost\n * @returns \n */\n public async quickStartup (providers: Array<AServiceProvider>, filtered: string[] = []) {\n this.registerProviders(providers, filtered)\n await this.registerConfiguredProviders()\n return this.boot()\n }\n\n /**\n * Dynamically register all configured providers\n */\n public async registerConfiguredProviders () {\n const providers = await this.getAllProviders()\n\n ProviderRegistry.setFiltered(this.filteredProviders)\n ProviderRegistry.registerMany(providers)\n\n for (const ProviderClass of ProviderRegistry.all()) {\n if (!ProviderClass) continue\n const provider = new ProviderClass(this)\n await this.register(provider)\n }\n }\n\n /**\n * Register service providers\n * \n * @param providers \n * @param filtered \n */\n registerProviders (providers: Array<AServiceProvider>, filtered: string[] = []): void {\n this.externalProviders.push(...providers)\n this.filteredProviders = filtered\n }\n\n /**\n * Register a provider\n */\n public async register (provider: ServiceProvider) {\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\n if (this.booted) return\n\n /**\n * If debug is enabled, let's show the loaded service provider info\n */\n if (\n process.env.APP_DEBUG === 'true' &&\n process.env.EXTENDED_DEBUG !== 'false' &&\n !this.providers.some(e => e.runsInConsole)\n ) {\n ProviderRegistry.log(this.providers)\n }\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 * 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: string) {\n return this.versions[key]?.replaceAll(/\\^|~/g, '')\n }\n\n /**\n * Returns the installed version of the system core and typescript.\n *\n * @returns \n */\n static getVersion (key: string) {\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 { Logger } from '@h3ravel/shared'\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 const option = this.input.options[key] ?? def\n return option === 'null' || option === 'undefined' ? undefined : option\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 /**\n * Log an info message\n */\n info (message: string): void {\n Logger.info(message)\n }\n\n /**\n * Log a warning message\n */\n warn (message: string): void {\n Logger.warn(message)\n }\n\n /**\n * Log a line message\n */\n line (message: string): void {\n Logger.log(message, 'white')\n }\n\n /**\n * Log a new line\n */\n newLine (count: number = 1): void {\n for (let i = 0; i < count; i++) {\n console.log('')\n }\n }\n\n /**\n * Log a success message\n */\n success (message: string): void {\n Logger.success(message)\n }\n\n /**\n * Log an error message\n */\n error (message: string): void {\n Logger.error(message)\n }\n\n /**\n * Log a debug message\n */\n debug (message: string | string[]): void {\n Logger.debug(message)\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\n public index?(..._ctx: any[]): any\n public store?(..._ctx: any[]): any\n public update?(..._ctx: any[]): any\n public destroy?(..._ctx: any[]): any\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 { Logger } from '@h3ravel/shared'\n\nexport class ConfigException extends Error {\n key: string\n\n constructor(key: string, type: 'any' | 'config' | 'env' = 'config', cause?: unknown) {\n const info = {\n any: `${key} not configured`,\n env: `${key} environment variable not configured`,\n config: `${key} config not set`,\n }\n\n const message = Logger.log([['ERROR:', 'bgRed'], [info[type], 'white']], ' ', false)\n\n super(message, {\n cause\n })\n\n this.key = key\n }\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\n const { app } = ctx.request\n\n /** \n * Bind HTTP Response instance to the service container\n */\n app.bind('http.response', () => {\n return ctx.response\n })\n\n /** \n * Bind HTTP Request instance to the service container\n */\n app.bind('http.request', () => {\n return ctx.request\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\nconst Inference = class { } as { new(): IServiceProvider }\n\nexport abstract class ServiceProvider extends Inference {\n /**\n * The current app instance\n */\n protected app: Application\n\n /**\n * Unique Identifier for the service providers\n */\n public static uid?: number\n\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 constructor(app: Application) {\n super()\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'\nimport { str } from '@h3ravel/support'\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 Object.assign(globalThis, {\n str,\n })\n }\n\n boot (): void | Promise<void> {\n try {\n Object.assign(globalThis, {\n asset: this.app.make('asset'),\n })\n } catch {/** */ }\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.12.2",
3
+ "version": "1.14.0",
4
4
  "description": "Core application container, lifecycle management and service providers for H3ravel.",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -53,8 +53,8 @@
53
53
  "semver": "^7.7.2",
54
54
  "srvx": "^0.8.7",
55
55
  "tslib": "^2.8.1",
56
- "@h3ravel/shared": "^0.20.11",
57
- "@h3ravel/support": "^0.11.0"
56
+ "@h3ravel/support": "^0.13.0",
57
+ "@h3ravel/shared": "^0.22.0"
58
58
  },
59
59
  "devDependencies": {
60
60
  "@types/semver": "^7.7.1",