@haskou/ddd-kernel 0.1.1 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -10
- package/dist/DomainEventConsumer-Bg-bOwmh.d.cts +11 -0
- package/dist/DomainEventConsumer-BroJmVty.d.ts +11 -0
- package/dist/DomainMessageBus-3jYk7TPw.d.ts +13 -0
- package/dist/DomainMessageBus-OyliPu3Z.d.cts +13 -0
- package/dist/MessageBus-BtUXnd0Y.d.cts +10 -0
- package/dist/MessageBus-oQ9BnW84.d.ts +10 -0
- package/dist/{NoFailedMessagesError-0YJKRWPF.d.ts → NoFailedMessagesError-BLpGI-G4.d.ts} +6 -1
- package/dist/{NoFailedMessagesError-Kz7CYWpT.d.cts → NoFailedMessagesError-BjxYoKTR.d.cts} +6 -1
- package/dist/PublisherHookErrorPolicy-CjouTcSR.d.cts +8 -0
- package/dist/PublisherHookErrorPolicy-DSsCNE6O.d.ts +8 -0
- package/dist/RetryPredicate-U7dYnQ4N.d.ts +15 -0
- package/dist/RetryPredicate-yT_z9zk1.d.cts +15 -0
- package/dist/{Scheduler-oigqNOUJ.d.ts → Scheduler-BW-U5Ccg.d.cts} +1 -1
- package/dist/{Scheduler-oigqNOUJ.d.cts → Scheduler-BW-U5Ccg.d.ts} +1 -1
- package/dist/ServiceClass-BkEHcXDi.d.cts +72 -0
- package/dist/ServiceClass-Bq_fBC5R.d.ts +72 -0
- package/dist/{Kernel-BWUOUWWI.d.cts → ShutdownHook-BjbnCKzr.d.cts} +49 -7
- package/dist/{Kernel-CUaqHa1s.d.ts → ShutdownHook-CMWLsfu-.d.ts} +49 -7
- package/dist/Subscription-4vuAAxax.d.cts +23 -0
- package/dist/Subscription-vtF0lEHP.d.ts +23 -0
- package/dist/adapters/index.cjs +665 -37
- package/dist/adapters/index.cjs.map +1 -1
- package/dist/adapters/index.d.cts +15 -13
- package/dist/adapters/index.d.ts +15 -13
- package/dist/adapters/index.js +659 -37
- package/dist/adapters/index.js.map +1 -1
- package/dist/adapters/pubsub/amqp/index.cjs +241 -16
- package/dist/adapters/pubsub/amqp/index.cjs.map +1 -1
- package/dist/adapters/pubsub/amqp/index.d.cts +16 -8
- package/dist/adapters/pubsub/amqp/index.d.ts +16 -8
- package/dist/adapters/pubsub/amqp/index.js +241 -16
- package/dist/adapters/pubsub/amqp/index.js.map +1 -1
- package/dist/adapters/pubsub/in-memory/index.cjs +96 -8
- package/dist/adapters/pubsub/in-memory/index.cjs.map +1 -1
- package/dist/adapters/pubsub/in-memory/index.d.cts +9 -3
- package/dist/adapters/pubsub/in-memory/index.d.ts +9 -3
- package/dist/adapters/pubsub/in-memory/index.js +96 -8
- package/dist/adapters/pubsub/in-memory/index.js.map +1 -1
- package/dist/adapters/pubsub/index.cjs +397 -27
- package/dist/adapters/pubsub/index.cjs.map +1 -1
- package/dist/adapters/pubsub/index.d.cts +89 -7
- package/dist/adapters/pubsub/index.d.ts +89 -7
- package/dist/adapters/pubsub/index.js +389 -26
- package/dist/adapters/pubsub/index.js.map +1 -1
- package/dist/adapters/ui/express/index.cjs +279 -11
- package/dist/adapters/ui/express/index.cjs.map +1 -1
- package/dist/adapters/ui/express/index.d.cts +127 -12
- package/dist/adapters/ui/express/index.d.ts +127 -12
- package/dist/adapters/ui/express/index.js +270 -11
- package/dist/adapters/ui/express/index.js.map +1 -1
- package/dist/adapters/ui/index.cjs +412 -27
- package/dist/adapters/ui/index.cjs.map +1 -1
- package/dist/adapters/ui/index.d.cts +7 -8
- package/dist/adapters/ui/index.d.ts +7 -8
- package/dist/adapters/ui/index.js +413 -27
- package/dist/adapters/ui/index.js.map +1 -1
- package/dist/adapters/ui/routes/index.cjs +136 -9
- package/dist/adapters/ui/routes/index.cjs.map +1 -1
- package/dist/adapters/ui/routes/index.js +136 -9
- package/dist/adapters/ui/routes/index.js.map +1 -1
- package/dist/contracts/index.cjs +16 -17
- package/dist/contracts/index.cjs.map +1 -1
- package/dist/contracts/index.d.cts +10 -2
- package/dist/contracts/index.d.ts +10 -2
- package/dist/contracts/index.js +16 -17
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/kernel/index.cjs.map +1 -1
- package/dist/contracts/kernel/index.d.cts +7 -1
- package/dist/contracts/kernel/index.d.ts +7 -1
- package/dist/contracts/pubsub/index.cjs.map +1 -1
- package/dist/contracts/pubsub/index.d.cts +5 -1
- package/dist/contracts/pubsub/index.d.ts +5 -1
- package/dist/contracts/ui/index.cjs +16 -17
- package/dist/contracts/ui/index.cjs.map +1 -1
- package/dist/contracts/ui/index.d.cts +16 -16
- package/dist/contracts/ui/index.d.ts +16 -16
- package/dist/contracts/ui/index.js +16 -17
- package/dist/contracts/ui/index.js.map +1 -1
- package/dist/domain/index.cjs.map +1 -1
- package/dist/domain/index.d.cts +6 -2
- package/dist/domain/index.d.ts +6 -2
- package/dist/domain/index.js.map +1 -1
- package/dist/index.cjs +152 -26
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +8 -7
- package/dist/index.d.ts +8 -7
- package/dist/index.js +152 -26
- package/dist/index.js.map +1 -1
- package/dist/infrastructure/dependency-injection/index.cjs +119 -3
- package/dist/infrastructure/dependency-injection/index.cjs.map +1 -1
- package/dist/infrastructure/dependency-injection/index.d.cts +4 -1
- package/dist/infrastructure/dependency-injection/index.d.ts +4 -1
- package/dist/infrastructure/dependency-injection/index.js +119 -3
- package/dist/infrastructure/dependency-injection/index.js.map +1 -1
- package/dist/infrastructure/express/index.cjs +279 -11
- package/dist/infrastructure/express/index.cjs.map +1 -1
- package/dist/infrastructure/express/index.d.cts +7 -8
- package/dist/infrastructure/express/index.d.ts +7 -8
- package/dist/infrastructure/express/index.js +270 -11
- package/dist/infrastructure/express/index.js.map +1 -1
- package/dist/infrastructure/scheduler/index.cjs +136 -9
- package/dist/infrastructure/scheduler/index.cjs.map +1 -1
- package/dist/infrastructure/scheduler/index.d.cts +2 -2
- package/dist/infrastructure/scheduler/index.d.ts +2 -2
- package/dist/infrastructure/scheduler/index.js +136 -9
- package/dist/infrastructure/scheduler/index.js.map +1 -1
- package/package.json +92 -17
- package/dist/Consumer-CC8ZRCsd.d.cts +0 -17
- package/dist/Consumer-CeT0Wbxb.d.ts +0 -17
- package/dist/DomainEventConsumer-3WBMSSr2.d.cts +0 -7
- package/dist/DomainEventConsumer-B4hkIUmP.d.ts +0 -7
- package/dist/DomainEventPublisher-8G0lvmdy.d.cts +0 -7
- package/dist/DomainEventPublisher-DhGgM3f2.d.ts +0 -7
- package/dist/ServiceClass-BmNw8fJj.d.cts +0 -37
- package/dist/ServiceClass-C7NCKdSS.d.ts +0 -37
- package/dist/ShutdownHook-BGskq2-q.d.ts +0 -9
- package/dist/ShutdownHook-Dib5uNKB.d.cts +0 -9
- package/dist/Subscription-Bwkb_did.d.ts +0 -9
- package/dist/Subscription-P9WROD_6.d.cts +0 -9
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/adapters/db/in-memory/InMemoryRepository.ts","../../src/adapters/db/mongo/MongoRepository.ts","../../src/adapters/kernel/console/ConsoleKernelLogger.ts","../../src/Kernel.ts","../../src/infrastructure/dependency-injection/DependencyInjection.ts","../../src/adapters/pubsub/Consumer.ts","../../src/adapters/pubsub/amqp/AmqpMessageBusAdapter.ts","../../src/adapters/pubsub/amqp/InvalidDomainEventError.ts","../../src/adapters/pubsub/amqp/NoFailedMessagesError.ts","../../src/adapters/pubsub/in-memory/InMemoryEventBus.ts","../../src/adapters/pubsub/in-memory/InMemoryPubSub.ts","../../src/adapters/ui/express/ExpressKernelServer.ts","../../src/adapters/ui/express/RoutePrefix.ts","../../src/adapters/ui/routes/Route.ts"],"sourcesContent":["import type { Repository } from '../../../contracts/index.js';\n\nexport class InMemoryRepository<\n TEntity extends { id: TId },\n TId,\n> implements Repository<TEntity, TId> {\n private readonly entities = new Map<TId, TEntity>();\n\n public findById(id: TId): Promise<TEntity | null> {\n return Promise.resolve(this.entities.get(id) ?? null);\n }\n\n public save(entity: TEntity): Promise<void> {\n this.entities.set(entity.id, entity);\n\n return Promise.resolve();\n }\n\n public delete(id: TId): Promise<void> {\n this.entities.delete(id);\n\n return Promise.resolve();\n }\n}\n","import type { Collection, Filter } from 'mongodb';\n\nimport type { Repository } from '../../../contracts/index.js';\nimport type { MongoDocumentMapper } from './MongoDocumentMapper.js';\n\nexport class MongoRepository<\n TEntity,\n TDocument extends { id: TId },\n TId,\n> implements Repository<TEntity, TId> {\n constructor(\n private readonly collection: Collection<TDocument>,\n private readonly mapper: MongoDocumentMapper<TEntity, TDocument, TId>,\n ) {}\n\n public async findById(id: TId): Promise<TEntity | null> {\n const document = await this.collection.findOne({\n id,\n } as Filter<TDocument>);\n\n if (!document) {\n return null;\n }\n\n return this.mapper.toEntity(document as TDocument);\n }\n\n public async save(entity: TEntity): Promise<void> {\n const document = this.mapper.toDocument(entity);\n\n await this.collection.updateOne(\n { id: document.id } as Filter<TDocument>,\n { $set: document },\n { upsert: true },\n );\n }\n\n public async delete(id: TId): Promise<void> {\n await this.collection.deleteOne({\n id,\n } as Filter<TDocument>);\n }\n}\n","import type { KernelLogger } from '../../../contracts/index.js';\n\nexport class ConsoleKernelLogger implements KernelLogger {\n public debug(message: string): void {\n // eslint-disable-next-line no-console\n console.debug(message);\n }\n\n public error(message: string): void {\n // eslint-disable-next-line no-console\n console.error(message);\n }\n\n public info(message: string): void {\n // eslint-disable-next-line no-console\n console.info(message);\n }\n\n public warn(message: string): void {\n // eslint-disable-next-line no-console\n console.warn(message);\n }\n}\n","import path from 'node:path';\n\nimport type { Consumer } from './adapters/pubsub/index.js';\nimport type { Route } from './adapters/ui/routes/index.js';\nimport type {\n ConsumerMiddleware,\n KernelLogger,\n ShutdownHook,\n} from './contracts/index.js';\nimport type { ServiceClass } from './infrastructure/dependency-injection/index.js';\nimport type { Initializer, Runtime } from './infrastructure/lifecycle/index.js';\nimport type { Scheduler } from './infrastructure/scheduler/index.js';\nimport type { KernelOptions } from './kernel/KernelOptions.js';\nimport type { ShutdownCandidate } from './kernel/ShutdownCandidate.js';\n\nimport { ConsoleKernelLogger } from './adapters/kernel/index.js';\nimport { DependencyInjection } from './infrastructure/dependency-injection/index.js';\n\nexport type { KernelOptions } from './kernel/KernelOptions.js';\n\nexport class Kernel {\n private static readonly stateKey = Symbol.for(\n '@haskou/ddd-kernel/kernel-state',\n );\n\n private readonly consumerMiddlewares: ConsumerMiddleware[] = [];\n private readonly consumersList: Consumer[] = [];\n private readonly loggerInstance: KernelLogger;\n private readonly routesList: ServiceClass<Route>[] = [];\n private readonly schedulersList: Scheduler[] = [];\n private readonly shutdownHooks: ShutdownHook[] = [];\n private dependencyInjectionInstance: DependencyInjection | undefined;\n\n private static get state(): { activeKernel?: Kernel } {\n const stateContainer = globalThis as typeof globalThis & {\n [Kernel.stateKey]?: { activeKernel?: Kernel };\n };\n\n stateContainer[Kernel.stateKey] = stateContainer[Kernel.stateKey] ?? {};\n\n return stateContainer[Kernel.stateKey] as { activeKernel?: Kernel };\n }\n\n public static get configDirectory(): string {\n return path.resolve(Kernel.rootDirectory, 'config');\n }\n\n public static get consumers(): Consumer[] {\n return Kernel.getActiveKernel().consumers;\n }\n\n public static get consumerMiddleware(): ConsumerMiddleware[] {\n return Kernel.getActiveKernel().consumerMiddleware;\n }\n\n public static get di(): DependencyInjection {\n return Kernel.getActiveKernel().di;\n }\n\n public static get logger(): KernelLogger {\n return Kernel.getActiveKernel().logger;\n }\n\n public static get rootDirectory(): string {\n return process.cwd();\n }\n\n public static get routes(): ServiceClass<Route>[] {\n return Kernel.getActiveKernel().routes;\n }\n\n public static get schedulers(): Scheduler[] {\n return Kernel.getActiveKernel().schedulers;\n }\n\n public static get sourceDirectory(): string {\n return path.resolve(Kernel.rootDirectory, 'src');\n }\n\n private static getActiveKernel(): Kernel {\n if (!Kernel.state.activeKernel) {\n Kernel.state.activeKernel = new Kernel();\n }\n\n return Kernel.state.activeKernel;\n }\n\n constructor(private readonly options: KernelOptions = {}) {\n this.loggerInstance = options.logger ?? new ConsoleKernelLogger();\n this.dependencyInjectionInstance = options.di;\n Kernel.state.activeKernel = this;\n }\n\n private async closeCandidate(candidate: ShutdownCandidate): Promise<void> {\n if (candidate.shutdown) {\n await candidate.shutdown();\n\n return;\n }\n\n if (candidate.close) {\n await candidate.close();\n\n return;\n }\n\n if (candidate.stop) {\n await candidate.stop();\n\n return;\n }\n\n if (candidate.flush) {\n await candidate.flush();\n }\n }\n\n private getConsumerFromClass(\n ClassDefinition: ServiceClass<Consumer>,\n ): Consumer {\n return this.di.getService<Consumer>(ClassDefinition);\n }\n\n private getInitializerFromClass(\n ClassDefinition: ServiceClass<Initializer>,\n ): Initializer {\n return this.di.getService<Initializer>(ClassDefinition);\n }\n\n private getRuntimeFromClass(ClassDefinition: ServiceClass<Runtime>): Runtime {\n return this.di.getService<Runtime>(ClassDefinition);\n }\n\n private getSchedulerFromClass(\n ClassDefinition: ServiceClass<Scheduler>,\n ): Scheduler {\n return this.di.getService<Scheduler>(ClassDefinition);\n }\n\n public get consumers(): Consumer[] {\n return this.consumersList;\n }\n\n public get consumerMiddleware(): ConsumerMiddleware[] {\n return this.consumerMiddlewares;\n }\n\n public get di(): DependencyInjection {\n if (!this.dependencyInjectionInstance) {\n throw new Error('Kernel dependency injection has not been initialized.');\n }\n\n return this.dependencyInjectionInstance;\n }\n\n public get logger(): KernelLogger {\n return this.loggerInstance;\n }\n\n public get routes(): ServiceClass<Route>[] {\n return this.routesList;\n }\n\n public get schedulers(): Scheduler[] {\n return this.schedulersList;\n }\n\n public async dependencyInjection(): Promise<void> {\n this.dependencyInjectionInstance =\n this.dependencyInjectionInstance ??\n DependencyInjection.configure({\n containerBuild: process.env.CONTAINER_BUILD === 'true',\n servicesYamlPath:\n this.options.servicesYamlPath ??\n path.resolve(Kernel.configDirectory, 'container', 'services.yaml'),\n sourceDirectory: this.options.sourceDirectory ?? Kernel.sourceDirectory,\n });\n\n await this.dependencyInjectionInstance.compile();\n }\n\n public getRoutes(): ServiceClass<Route>[] {\n return this.routes;\n }\n\n public registerConsumerMiddleware(\n ...middlewares: ConsumerMiddleware[]\n ): void {\n this.consumerMiddlewares.push(...middlewares);\n }\n\n public registerConsumers(\n ...ClassDefinitions: ServiceClass<Consumer>[]\n ): void {\n for (const ClassDefinition of ClassDefinitions) {\n this.consumersList.push(this.getConsumerFromClass(ClassDefinition));\n }\n }\n\n public registerConsumerInstances(...consumers: Consumer[]): void {\n this.consumersList.push(...consumers);\n }\n\n public registerRoutes(...ClassDefinitions: ServiceClass<Route>[]): void {\n this.routesList.push(...ClassDefinitions);\n }\n\n public registerSchedulers(\n ...ClassDefinitions: ServiceClass<Scheduler>[]\n ): void {\n for (const ClassDefinition of ClassDefinitions) {\n this.schedulersList.push(this.getSchedulerFromClass(ClassDefinition));\n }\n }\n\n public registerSchedulerInstances(...schedulers: Scheduler[]): void {\n this.schedulersList.push(...schedulers);\n }\n\n public registerShutdownHook(hook: ShutdownHook): void {\n this.shutdownHooks.push(hook);\n }\n\n public removeConsumers(): void {\n this.consumersList.length = 0;\n }\n\n public removeRoutes(): void {\n this.routesList.length = 0;\n }\n\n public removeSchedulers(): void {\n this.schedulersList.length = 0;\n }\n\n public async runConsumers(): Promise<void> {\n for (const consumer of this.consumersList) {\n await consumer.init();\n }\n }\n\n public async runInitializers(\n ...ClassDefinitions: ServiceClass<Initializer>[]\n ): Promise<void> {\n for (const ClassDefinition of ClassDefinitions) {\n await this.getInitializerFromClass(ClassDefinition).ensure();\n }\n }\n\n public async runRuntimes(\n ...ClassDefinitions: ServiceClass<Runtime>[]\n ): Promise<void> {\n for (const ClassDefinition of ClassDefinitions) {\n const runtime = this.getRuntimeFromClass(ClassDefinition);\n\n await runtime.run();\n this.registerShutdownHook(() =>\n this.closeCandidate(runtime as ShutdownCandidate),\n );\n }\n }\n\n public async runSchedulerNowAndSchedule(\n ClassDefinition: ServiceClass<Scheduler>,\n ): Promise<void> {\n const scheduler = this.getSchedulerFromClass(ClassDefinition);\n\n await scheduler.runOnce();\n await scheduler.init();\n this.schedulersList.push(scheduler);\n }\n\n public async runSchedulers(): Promise<void> {\n for (const scheduler of this.schedulersList) {\n await scheduler.init();\n }\n }\n\n public async shutdown(): Promise<void> {\n for (const consumer of [...this.consumersList].reverse()) {\n await this.closeCandidate(consumer as ShutdownCandidate);\n }\n\n for (const scheduler of [...this.schedulersList].reverse()) {\n await this.closeCandidate(scheduler as ShutdownCandidate);\n }\n\n for (const hook of [...this.shutdownHooks].reverse()) {\n await hook();\n }\n\n await this.closeCandidate(this.loggerInstance as ShutdownCandidate);\n }\n}\n\nexport function createKernel(options?: KernelOptions): Kernel {\n return new Kernel(options);\n}\n\nexport default Kernel;\n","import fs from 'fs-extra';\nimport {\n Autowire,\n ContainerBuilder,\n ServiceFile,\n YamlFileLoader,\n} from 'node-dependency-injection';\nimport path from 'node:path';\n\nimport type { ServiceResolver } from '../../contracts/index.js';\nimport type { ContainerInternals } from './ContainerInternals.js';\nimport type { DefinitionMetadata } from './DefinitionMetadata.js';\nimport type { DependencyInjectionOptions } from './DependencyInjectionOptions.js';\n\nexport class DependencyInjection implements ServiceResolver {\n private static configuredInstance: DependencyInjection | undefined;\n private autowire: Autowire | undefined;\n private loader: YamlFileLoader | undefined;\n private readonly container: ContainerBuilder;\n\n public static configure(\n options: DependencyInjectionOptions,\n ): DependencyInjection {\n DependencyInjection.configuredInstance = new DependencyInjection(options);\n\n return DependencyInjection.configuredInstance;\n }\n\n public static get instance(): DependencyInjection {\n if (!DependencyInjection.configuredInstance) {\n throw new Error('DependencyInjection has not been configured.');\n }\n\n return DependencyInjection.configuredInstance;\n }\n\n constructor(\n private readonly options: DependencyInjectionOptions = {\n containerBuild: process.env.CONTAINER_BUILD === 'true',\n servicesYamlPath: path.resolve(\n process.cwd(),\n 'config',\n 'container',\n 'services.yaml',\n ),\n sourceDirectory: path.resolve(process.cwd(), 'src'),\n },\n ) {\n this.container = new ContainerBuilder(false, this.options.sourceDirectory);\n }\n\n private get definitions(): Map<string, DefinitionMetadata> {\n const container = this.container as unknown as ContainerInternals;\n\n return container._definitions || new Map();\n }\n\n private get aliases(): Map<string, string> {\n const container = this.container as unknown as ContainerInternals;\n\n return container._alias || new Map();\n }\n\n private async ensureFolderExists(filePath: string): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n }\n\n private getServiceClassName(serviceName: unknown): string | undefined {\n return typeof serviceName === 'function' ? serviceName.name : undefined;\n }\n\n private parentMatchesService(\n parentId: string | null | undefined,\n serviceClassName: string,\n ): boolean {\n if (!parentId) {\n return false;\n }\n\n const parentName = Buffer.from(parentId, 'base64').toString('utf8');\n\n return parentName.endsWith(`__${serviceClassName}__${serviceClassName}`);\n }\n\n private serviceIdMatchesService(\n serviceId: string,\n serviceClassName: string,\n ): boolean {\n const serviceName = Buffer.from(serviceId, 'base64').toString('utf8');\n\n return serviceName.endsWith(`__${serviceClassName}__${serviceClassName}`);\n }\n\n private findConcreteChildServiceId(serviceName: unknown): string | undefined {\n const serviceClassName = this.getServiceClassName(serviceName);\n\n if (!serviceClassName) {\n return undefined;\n }\n\n const matches = [...this.definitions.entries()]\n .filter(([, definition]) => definition._abstract !== true)\n .filter(([, definition]) =>\n this.parentMatchesService(definition._parent, serviceClassName),\n )\n .map(([id]) => id);\n\n return matches[matches.length - 1];\n }\n\n private findRegisteredServiceId(serviceName: unknown): string | undefined {\n const serviceClassName = this.getServiceClassName(serviceName);\n\n if (!serviceClassName) {\n return undefined;\n }\n\n const matches = [...this.definitions.keys()].filter((id) =>\n this.serviceIdMatchesService(id, serviceClassName),\n );\n\n return matches[matches.length - 1];\n }\n\n private findAliasServiceId(serviceName: unknown): string | undefined {\n const serviceClassName = this.getServiceClassName(serviceName);\n\n if (!serviceClassName) {\n return undefined;\n }\n\n const matches = [...this.aliases.keys()].filter((id) =>\n this.serviceIdMatchesService(id, serviceClassName),\n );\n\n return matches[matches.length - 1];\n }\n\n private registerParentAliases(): void {\n for (const [id, definition] of this.definitions.entries()) {\n if (definition._abstract === true || !definition._parent) {\n continue;\n }\n\n this.container.setAlias(definition._parent, id);\n }\n }\n\n public async compile(): Promise<void> {\n if (this.options.containerBuild) {\n await this.ensureFolderExists(this.options.servicesYamlPath);\n this.autowire = new Autowire(this.container);\n this.autowire.serviceFile = new ServiceFile(\n this.options.servicesYamlPath,\n false,\n );\n await this.autowire.process();\n } else {\n this.loader = new YamlFileLoader(this.container);\n await this.loader.load(this.options.servicesYamlPath);\n }\n\n this.registerParentAliases();\n await this.container.compile();\n }\n\n public getService<T>(serviceName: unknown): T {\n const childServiceId = this.findConcreteChildServiceId(serviceName);\n\n if (childServiceId) {\n return this.container.get<T>(childServiceId);\n }\n\n const aliasServiceId = this.findAliasServiceId(serviceName);\n\n if (aliasServiceId) {\n return this.container.get<T>(aliasServiceId);\n }\n\n const registeredServiceId = this.findRegisteredServiceId(serviceName);\n\n if (registeredServiceId) {\n return this.container.get<T>(registeredServiceId);\n }\n\n return this.container.get<T>(serviceName);\n }\n}\n\nexport default DependencyInjection;\n","import type { ConsumerMiddleware } from '../../contracts/index.js';\nimport type { DomainEventConsumer } from '../../domain/DomainEventConsumer.js';\nimport type { DomainEvent } from '../../domain/index.js';\n\nimport { Kernel } from '../../Kernel.js';\n\nexport abstract class Consumer {\n constructor(private readonly consumer: DomainEventConsumer) {}\n\n private async runMiddleware(\n event: DomainEvent,\n middlewares: readonly ConsumerMiddleware[],\n index: number,\n ): Promise<void> {\n const middleware = middlewares[index];\n\n if (!middleware) {\n await this.handler(event);\n\n return;\n }\n\n await middleware.handle(event, () =>\n this.runMiddleware(event, middlewares, index + 1),\n );\n }\n\n public abstract get domainEvent(): typeof DomainEvent;\n\n public abstract get eventName(): string;\n\n public abstract get exchange(): string;\n\n public abstract get queueName(): string;\n\n public abstract handler(event: DomainEvent): Promise<void>;\n\n public async init(): Promise<void> {\n await this.consumer.consume(\n this.queueName,\n this.eventName,\n this.domainEvent,\n this.exchange,\n (event) => this.runMiddleware(event, Kernel.consumerMiddleware, 0),\n );\n }\n\n public get<T>(service: unknown): T {\n return Kernel.di.getService<T>(service);\n }\n}\n\nexport default Consumer;\n","import amqplib, {\n type Channel,\n type ChannelModel,\n type ConsumeMessage,\n type GetMessage,\n type MessagePropertyHeaders,\n type Options,\n} from 'amqplib';\nimport { randomUUID } from 'node:crypto';\n\nimport type {\n Constructor,\n DomainEvent,\n DomainEventConsumer,\n DomainEventPublisher,\n} from '../../../domain/index.js';\nimport type { AmqpMessage } from './AmqpMessage.js';\nimport type { AmqpMessageBusAdapterOptions } from './AmqpMessageBusAdapterOptions.js';\nimport type { ConsumerContext } from './ConsumerContext.js';\n\nimport { Kernel } from '../../../Kernel.js';\nimport { InvalidDomainEventError } from './InvalidDomainEventError.js';\nimport { NoFailedMessagesError } from './NoFailedMessagesError.js';\n\nexport default class AmqpMessageBusAdapter\n implements DomainEventConsumer, DomainEventPublisher\n{\n private channelInstance: Channel | undefined;\n private connection: ChannelModel | undefined;\n private readonly delayConsumers: string[] = [];\n private exchange: string;\n\n constructor(private readonly options: AmqpMessageBusAdapterOptions = {}) {\n this.exchange =\n options.exchange ?? options.serviceName ?? process.env.SERVICE_NAME ?? '';\n }\n\n private get dsn(): string {\n return this.options.dsn ?? process.env.TRANSPORT_DSN ?? '';\n }\n\n private get logger(): AmqpMessageBusAdapterOptions['logger'] {\n return this.options.logger ?? Kernel.logger;\n }\n\n private get maxRetries(): number | undefined {\n const configuredRetries =\n this.options.maxRetries ?? process.env.TRANSPORT_MAX_RETRIES;\n\n if (configuredRetries === undefined) {\n return undefined;\n }\n\n return Number(configuredRetries);\n }\n\n private get retryDelayInMilliseconds(): number {\n const retryDelayFromEnv = Number(process.env.TRANSPORT_RETRY_DELAY);\n\n return (\n this.options.retryDelayInMilliseconds ??\n (Number.isFinite(retryDelayFromEnv) ? retryDelayFromEnv : 1000)\n );\n }\n\n private instanceDomainEvent(\n DomainEventInstance: Constructor<DomainEvent>,\n message: AmqpMessage,\n ): DomainEvent {\n if (!message) {\n throw new InvalidDomainEventError(JSON.stringify(message));\n }\n\n return new DomainEventInstance(\n message.aggregate_id,\n message.attributes,\n message.event_id,\n message.occurred_on ? new Date(message.occurred_on) : new Date(),\n message.correlation_id,\n message.causation_id,\n );\n }\n\n private async handle(\n msg: ConsumeMessage,\n context: ConsumerContext,\n ): Promise<void> {\n const message = JSON.parse(msg.content.toString()) as AmqpMessage;\n\n this.logger?.info(\n `AMQP message bus (${context.queueName}) handling message: ${JSON.stringify(message)}`,\n );\n\n try {\n const domainEvent = this.instanceDomainEvent(\n context.DomainEventInstance,\n message,\n );\n\n await context.handler(domainEvent);\n } catch (error) {\n await this.handleError(msg, message, context, error);\n }\n }\n\n private async handleError(\n msg: ConsumeMessage,\n message: AmqpMessage,\n context: ConsumerContext,\n error: unknown,\n ): Promise<void> {\n this.logger?.error(error instanceof Error ? error.message : String(error));\n const headers = msg.properties.headers ?? {};\n const retryCount = Number(headers.retries ?? 0);\n\n if (this.maxRetries !== undefined && retryCount <= this.maxRetries) {\n await this.retry(message, headers, context);\n\n return;\n }\n\n await this.sendToDlx(message, context, String(error));\n }\n\n private async retry(\n message: AmqpMessage,\n headers: MessagePropertyHeaders,\n context: ConsumerContext,\n ): Promise<void> {\n const retry = Number(headers.retries || 1);\n const delayTimeInMs = retry * this.retryDelayInMilliseconds;\n const delayedQueueName = `${context.queueName}_delayed_${delayTimeInMs}`;\n const delayedRoutingKey = `${context.queueName}_${context.bindingKey}_delayed_${delayTimeInMs}`;\n const consumerTag = `${delayedQueueName}_${randomUUID()}`;\n\n this.logger?.info(`Retry # ${retry}`);\n\n if (!this.delayConsumers.includes(delayedQueueName)) {\n await this.registerDelayedConsumer(\n delayedQueueName,\n delayedRoutingKey,\n delayTimeInMs,\n consumerTag,\n context,\n );\n }\n\n try {\n const domainEvent = this.instanceDomainEvent(\n context.DomainEventInstance,\n message,\n );\n\n context.channel.publish(\n this.exchange,\n delayedRoutingKey,\n Buffer.from(JSON.stringify(message)),\n this.opts(domainEvent, retry),\n );\n } catch (error: unknown) {\n await context.channel.cancel(consumerTag);\n this.logger?.error(\n error instanceof Error ? error.message : String(error),\n );\n }\n }\n\n private async registerDelayedConsumer(\n delayedQueueName: string,\n delayedRoutingKey: string,\n delayTimeInMs: number,\n consumerTag: string,\n context: ConsumerContext,\n ): Promise<void> {\n await context.channel.assertExchange(this.exchange, 'topic', {\n durable: true,\n });\n await context.channel.assertQueue(delayedQueueName, {\n autoDelete: true,\n deadLetterExchange: this.exchange,\n deadLetterRoutingKey: delayedRoutingKey,\n durable: false,\n messageTtl: delayTimeInMs,\n });\n await context.channel.bindQueue(\n delayedQueueName,\n this.exchange,\n delayedRoutingKey,\n );\n this.delayConsumers.push(delayedQueueName);\n await context.channel.consume(\n delayedQueueName,\n async (msg: ConsumeMessage | null) => {\n if (!msg) {\n return;\n }\n\n await new Promise((resolve) => setTimeout(resolve, delayTimeInMs));\n await this.handle(msg, context);\n this.removeDelayConsumer(delayedQueueName);\n await context.channel.cancel(consumerTag);\n },\n { consumerTag, noAck: true },\n );\n }\n\n private removeDelayConsumer(delayedQueueName: string): void {\n const index = this.delayConsumers.indexOf(delayedQueueName);\n\n if (index !== -1) {\n this.delayConsumers.splice(index, 1);\n }\n }\n\n private async sendToDlx(\n message: AmqpMessage,\n context: ConsumerContext,\n error?: string,\n ): Promise<void> {\n await context.channel.assertExchange(this.exchange, 'topic');\n const dlxQueueName = `${context.queueName}_dlx`;\n const dlxRoutingKey = `${context.queueName}_${context.bindingKey}_dlx`;\n\n await context.channel.assertQueue(dlxQueueName, {\n deadLetterExchange: this.exchange,\n deadLetterRoutingKey: dlxRoutingKey,\n durable: true,\n });\n await context.channel.bindQueue(dlxQueueName, this.exchange, dlxRoutingKey);\n\n try {\n const domainEvent = this.instanceDomainEvent(\n context.DomainEventInstance,\n message,\n );\n\n context.channel.publish(\n this.exchange,\n dlxRoutingKey,\n Buffer.from(JSON.stringify(message)),\n this.opts(domainEvent, message.retries, error),\n );\n } catch (publishError: unknown) {\n this.logger?.error(\n publishError instanceof Error\n ? publishError.message\n : String(publishError),\n );\n }\n }\n\n private async connect(): Promise<void> {\n this.connection = await amqplib.connect(this.getConnectionDsn());\n this.channelInstance = await this.connection.createChannel();\n this.channelInstance\n .on('close', async () => {\n this.logger?.error('AMQP message bus event close');\n await this.reconnect();\n })\n .on('error', async (error) => {\n this.logger?.error(`AMQP message bus event error: ${error.message}`);\n await this.reconnect();\n });\n }\n\n private async reconnect(): Promise<void> {\n await this.connect();\n\n for (const consumer of Kernel.consumers) {\n await consumer.init();\n }\n }\n\n private async channel(forceNew = false): Promise<Channel> {\n if (forceNew) {\n const connection = await amqplib.connect(this.getConnectionDsn());\n\n return connection.createChannel();\n }\n\n if (!this.channelInstance) {\n await this.connect();\n }\n\n if (!this.channelInstance) {\n throw new Error('AMQP channel could not be created.');\n }\n\n await this.channelInstance.assertExchange(this.exchange, 'topic', {\n durable: true,\n });\n\n return this.channelInstance;\n }\n\n private getConnectionDsn(): string {\n const separator = this.dsn.includes('?') ? '&' : '?';\n\n return `${this.dsn}${separator}heartbeat=60`;\n }\n\n private opts(\n event: DomainEvent,\n retries?: number,\n error?: string,\n ): Options.Publish {\n return {\n appId: this.options.serviceName ?? process.env.SERVICE_NAME,\n contentEncoding: 'utf-8',\n contentType: 'application/json',\n deliveryMode: 2,\n headers: {\n error,\n retries: retries ? retries + 1 : 0,\n },\n messageId: event.eventId,\n priority: 0,\n timestamp: event.occurredOn.getTime(),\n type: event.eventName(),\n };\n }\n\n private getMessagesToRetry(\n requestedMessagesToRetry: number | undefined,\n availableMessages: number,\n ): number {\n return requestedMessagesToRetry ?? availableMessages;\n }\n\n private async retryDlxMessage(\n msg: ConsumeMessage | GetMessage,\n DomainEventInstance: Constructor<DomainEvent>,\n handler: (event: DomainEvent) => Promise<void>,\n channel: Channel,\n ): Promise<void> {\n const content = msg.content.toString();\n\n this.logger?.info(`Retrying message from DLX ${content}`);\n\n try {\n const message = JSON.parse(content) as AmqpMessage;\n const domainEvent = this.instanceDomainEvent(\n DomainEventInstance,\n message,\n );\n\n await handler(domainEvent);\n this.logger?.info(`${content} successfully handled.`);\n channel.ack(msg);\n } catch (error: Error | unknown) {\n const errorMessage =\n error instanceof Error ? error.message : String(error);\n\n this.logger?.error(`${content} error with ${errorMessage}.`);\n channel.nack(msg);\n }\n }\n\n public async areQueuesBound(): Promise<boolean> {\n if (Kernel.consumers.length === 0) {\n return false;\n }\n\n const channel = await this.channel();\n\n for (const consumer of Kernel.consumers) {\n const queueChecker = await channel.checkQueue(consumer.queueName);\n\n if (queueChecker.consumerCount !== 0) {\n return false;\n }\n }\n\n return true;\n }\n\n public async consumeDlx(\n queueName: string,\n DomainEventInstance: Constructor<DomainEvent>,\n handler: (event: DomainEvent) => Promise<void>,\n messagesToRetry?: number,\n ): Promise<void> {\n const dlxQueueName = `${queueName}_dlx`;\n const channel = await this.channel(true);\n\n channel.on('error', () => {\n this.logger?.error('AMQP message bus event error');\n });\n\n const queue = await channel.checkQueue(dlxQueueName);\n const messagesToRetryCount = this.getMessagesToRetry(\n messagesToRetry,\n queue.messageCount,\n );\n\n this.logger?.info(\n `Retrying ${messagesToRetryCount} messages from DLX ${dlxQueueName}`,\n );\n\n if (messagesToRetryCount > 0 && queue.messageCount !== 0) {\n for (let index = 0; index < messagesToRetryCount; index++) {\n const msg = await channel.get(dlxQueueName);\n\n if (msg === false) {\n continue;\n }\n\n await this.retryDlxMessage(msg, DomainEventInstance, handler, channel);\n }\n\n return;\n }\n\n throw new NoFailedMessagesError(dlxQueueName);\n }\n\n public async consume(\n queueName: string,\n bindingKey: string,\n DomainEventInstance: Constructor<DomainEvent>,\n exchange: string,\n handler: (event: DomainEvent) => Promise<void>,\n ): Promise<void> {\n const channel = await this.channel();\n\n await channel.assertQueue(queueName, { durable: true });\n await channel.assertExchange(exchange, 'topic');\n await channel.prefetch(1);\n await channel.bindQueue(queueName, exchange, bindingKey);\n\n const context: ConsumerContext = {\n bindingKey,\n channel,\n DomainEventInstance,\n handler,\n queueName,\n };\n\n await channel.consume(queueName, async (msg: ConsumeMessage | null) => {\n if (!msg) {\n return;\n }\n\n await this.handle(msg, context);\n channel.ack(msg);\n });\n }\n\n public async publish(domainEvents: DomainEvent[]): Promise<void> {\n const channel = await this.channel();\n\n for (const event of domainEvents) {\n channel.publish(\n this.exchange,\n event.eventName(),\n Buffer.from(event.decode()),\n this.opts(event),\n );\n }\n }\n\n public async close(): Promise<void> {\n await this.channelInstance?.close();\n await this.connection?.close();\n this.channelInstance = undefined;\n this.connection = undefined;\n }\n}\n","export class InvalidDomainEventError extends Error {\n constructor(message: string) {\n super(`Invalid domain event: ${message}`);\n this.name = 'InvalidDomainEventError';\n }\n}\n","export class NoFailedMessagesError extends Error {\n constructor(queueName: string) {\n super(`No failed messages found in \"${queueName}\".`);\n this.name = 'NoFailedMessagesError';\n }\n}\n","import type {\n DomainEvent,\n HandlerContext,\n MessageHandler,\n} from '../../../contracts/index.js';\n\nexport class InMemoryEventBus {\n private readonly handlers = new Map<\n string,\n MessageHandler<DomainEvent, void>[]\n >();\n\n constructor(private readonly context: HandlerContext) {}\n\n public subscribe<TEvent extends DomainEvent>(\n name: TEvent['name'],\n handler: MessageHandler<TEvent, void>,\n ): void {\n const handlers = this.handlers.get(name) ?? [];\n\n handlers.push(handler as MessageHandler<DomainEvent, void>);\n this.handlers.set(name, handlers);\n }\n\n public async publish<TEvent extends DomainEvent>(\n event: TEvent,\n ): Promise<void> {\n const handlers = this.handlers.get(event.name) ?? [];\n\n for (const handler of handlers) {\n await handler(event, this.context);\n }\n }\n}\n","import type {\n HandlerContext,\n Message,\n MessageHandler,\n Subscription,\n} from '../../../contracts/index.js';\n\nexport class InMemoryPubSub {\n private readonly consumers = new Map<\n string,\n Set<MessageHandler<Message, void>>\n >();\n\n constructor(private readonly context: HandlerContext) {}\n\n public async publish<TMessage extends Message>(\n topic: string,\n message: TMessage,\n ): Promise<void> {\n const consumers = this.consumers.get(topic) ?? new Set();\n\n for (const consumer of consumers) {\n await consumer(message, this.context);\n }\n }\n\n public subscribe<TMessage extends Message>(\n topic: string,\n consumer: MessageHandler<TMessage, void>,\n ): Promise<Subscription> {\n const consumers =\n this.consumers.get(topic) ?? new Set<MessageHandler<Message, void>>();\n const castConsumer = consumer as MessageHandler<Message, void>;\n\n consumers.add(castConsumer);\n this.consumers.set(topic, consumers);\n\n return Promise.resolve({\n close: () => {\n consumers.delete(castConsumer);\n\n return Promise.resolve();\n },\n });\n }\n}\n","import type { ErrorRequestHandler } from 'express';\n\nimport { createExpressServer } from 'routing-controllers';\n\nimport type { ExpressKernelServerOptions } from './ExpressKernelServerOptions.js';\nimport type { HttpApp } from './HttpApp.js';\nimport type { HttpServer } from './HttpServer.js';\n\nexport class ExpressKernelServer {\n private appInstance: HttpApp | undefined;\n private serverInstance: HttpServer | undefined;\n\n constructor(private readonly options: ExpressKernelServerOptions) {}\n\n private registerErrorHandlers(app: HttpApp): void {\n const handlers = this.options.errorHandlers ?? [this.defaultErrorHandler()];\n\n for (const handler of handlers) {\n app.use(handler);\n }\n }\n\n private defaultErrorHandler(): ErrorRequestHandler {\n return (error, request, response) => {\n void request;\n\n response.status(500).json({\n error: error instanceof Error ? error.message : String(error),\n });\n };\n }\n\n public get app(): HttpApp {\n if (!this.appInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.appInstance;\n }\n\n public get server(): HttpServer {\n if (!this.serverInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.serverInstance;\n }\n\n public close(): Promise<void> {\n if (!this.serverInstance) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n this.serverInstance?.close((error?: Error) => {\n if (error) {\n reject(error);\n\n return;\n }\n\n this.serverInstance = undefined;\n this.appInstance = undefined;\n resolve();\n });\n });\n }\n\n public run(): Promise<void> {\n const app = createExpressServer({\n controllers: this.options.kernel.getRoutes(),\n routePrefix: this.options.routePrefix,\n }) as HttpApp;\n\n for (const middleware of this.options.middlewares ?? []) {\n app.use(middleware);\n }\n\n this.registerErrorHandlers(app);\n this.appInstance = app;\n\n return new Promise((resolve) => {\n this.serverInstance = app.listen(this.options.port ?? 3000, () => {\n resolve();\n });\n });\n }\n}\n","export class RoutePrefix {\n private readonly value: string;\n\n public static fromEnvironment(value: string | undefined): RoutePrefix {\n return new RoutePrefix(value);\n }\n\n constructor(value: string | undefined) {\n if (!value || value === '/') {\n this.value = '';\n\n return;\n }\n\n const normalizedPrefix = value\n .trim()\n .replace(/^\\/+/, '')\n .replace(/\\/+$/, '');\n\n this.value = normalizedPrefix ? `/${normalizedPrefix}` : '';\n }\n\n public includes(requestPath: string): boolean {\n return (\n this.value.length > 0 &&\n (requestPath === this.value || requestPath.startsWith(`${this.value}/`))\n );\n }\n\n public isEmpty(): boolean {\n return this.value.length === 0;\n }\n\n public toString(): string {\n return this.value;\n }\n}\n","import { Kernel } from '../../../Kernel.js';\n\nexport abstract class Route {\n public get<T>(service: unknown): T {\n return Kernel.di.getService<T>(service);\n }\n}\n\nexport default Route;\n"],"mappings":"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","names":["path","path"]}
|
|
1
|
+
{"version":3,"sources":["../../src/adapters/db/in-memory/InMemoryRepository.ts","../../src/adapters/db/mongo/MongoRepository.ts","../../src/adapters/kernel/console/ConsoleKernelLogger.ts","../../src/Kernel.ts","../../src/infrastructure/dependency-injection/DependencyInjection.ts","../../src/adapters/pubsub/ConsumerMiddlewarePipeline.ts","../../src/adapters/pubsub/Consumer.ts","../../src/adapters/pubsub/CorrelationConsumerMiddleware.ts","../../src/adapters/pubsub/DefaultPublisherHookErrorPolicy.ts","../../src/adapters/pubsub/IdempotencyConsumerMiddleware.ts","../../src/adapters/pubsub/InMemoryIdempotencyStore.ts","../../src/adapters/pubsub/PublisherHookPipeline.ts","../../src/adapters/pubsub/RetryConsumerMiddleware.ts","../../src/adapters/pubsub/amqp/AmqpMessageBusAdapter.ts","../../src/adapters/pubsub/amqp/InvalidDomainEventError.ts","../../src/adapters/pubsub/amqp/NoFailedMessagesError.ts","../../src/adapters/pubsub/in-memory/InMemoryEventBus.ts","../../src/adapters/pubsub/in-memory/InMemoryPubSub.ts","../../src/adapters/ui/express/ExpressKernelServer.ts","../../src/adapters/ui/express/HttpErrorHandler.ts","../../src/contracts/ui/HttpRouteStatusEnum.ts","../../src/adapters/ui/express/RoutePrefix.ts","../../src/adapters/ui/routes/Route.ts"],"sourcesContent":["import type { Repository } from '../../../contracts/index.js';\n\nexport class InMemoryRepository<\n TEntity extends { id: TId },\n TId,\n> implements Repository<TEntity, TId> {\n private readonly entities = new Map<TId, TEntity>();\n\n public findById(id: TId): Promise<TEntity | null> {\n return Promise.resolve(this.entities.get(id) ?? null);\n }\n\n public save(entity: TEntity): Promise<void> {\n this.entities.set(entity.id, entity);\n\n return Promise.resolve();\n }\n\n public delete(id: TId): Promise<void> {\n this.entities.delete(id);\n\n return Promise.resolve();\n }\n}\n","import type { Collection, Filter } from 'mongodb';\n\nimport type { Repository } from '../../../contracts/index.js';\nimport type { MongoDocumentMapper } from './MongoDocumentMapper.js';\n\nexport class MongoRepository<\n TEntity,\n TDocument extends { id: TId },\n TId,\n> implements Repository<TEntity, TId> {\n constructor(\n private readonly collection: Collection<TDocument>,\n private readonly mapper: MongoDocumentMapper<TEntity, TDocument, TId>,\n ) {}\n\n public async findById(id: TId): Promise<TEntity | null> {\n const document = await this.collection.findOne({\n id,\n } as Filter<TDocument>);\n\n if (!document) {\n return null;\n }\n\n return this.mapper.toEntity(document as TDocument);\n }\n\n public async save(entity: TEntity): Promise<void> {\n const document = this.mapper.toDocument(entity);\n\n await this.collection.updateOne(\n { id: document.id } as Filter<TDocument>,\n { $set: document },\n { upsert: true },\n );\n }\n\n public async delete(id: TId): Promise<void> {\n await this.collection.deleteOne({\n id,\n } as Filter<TDocument>);\n }\n}\n","import type { KernelLogger } from '../../../contracts/index.js';\n\nexport class ConsoleKernelLogger implements KernelLogger {\n public debug(message: string): void {\n // eslint-disable-next-line no-console\n console.debug(message);\n }\n\n public error(message: string): void {\n // eslint-disable-next-line no-console\n console.error(message);\n }\n\n public info(message: string): void {\n // eslint-disable-next-line no-console\n console.info(message);\n }\n\n public warn(message: string): void {\n // eslint-disable-next-line no-console\n console.warn(message);\n }\n}\n","import path from 'node:path';\n\nimport type { Consumer } from './adapters/pubsub/index.js';\nimport type { Route } from './adapters/ui/routes/index.js';\nimport type {\n ConsumerMiddleware,\n KernelLogger,\n ShutdownHook,\n} from './contracts/index.js';\nimport type { ServiceClass } from './infrastructure/dependency-injection/index.js';\nimport type { Initializer, Runtime } from './infrastructure/lifecycle/index.js';\nimport type { Scheduler } from './infrastructure/scheduler/index.js';\nimport type { KernelDependencyInjectionOptions } from './kernel/KernelDependencyInjectionOptions.js';\nimport type { KernelOptions } from './kernel/KernelOptions.js';\nimport type { ShutdownCandidate } from './kernel/ShutdownCandidate.js';\n\nimport { ConsoleKernelLogger } from './adapters/kernel/index.js';\nimport { DependencyInjection } from './infrastructure/dependency-injection/index.js';\n\nexport type { KernelDependencyInjectionOptions } from './kernel/KernelDependencyInjectionOptions.js';\nexport type { KernelOptions } from './kernel/KernelOptions.js';\n\nexport class Kernel {\n private static readonly stateKey = Symbol.for(\n '@haskou/ddd-kernel/kernel-state',\n );\n\n private readonly consumerMiddlewares: ConsumerMiddleware[] = [];\n private readonly consumersList: Consumer[] = [];\n private readonly loggerInstance: KernelLogger;\n private readonly routesList: ServiceClass<Route>[] = [];\n private readonly schedulersList: Scheduler[] = [];\n private readonly shutdownHooks: ShutdownHook[] = [];\n private dependencyInjectionInstance: DependencyInjection | undefined;\n\n private static get state(): { activeKernel?: Kernel } {\n const stateContainer = globalThis as typeof globalThis & {\n [Kernel.stateKey]?: { activeKernel?: Kernel };\n };\n\n stateContainer[Kernel.stateKey] = stateContainer[Kernel.stateKey] ?? {};\n\n return stateContainer[Kernel.stateKey] as { activeKernel?: Kernel };\n }\n\n public static get configDirectory(): string {\n return path.resolve(Kernel.rootDirectory, 'config');\n }\n\n public static get consumers(): Consumer[] {\n return Kernel.getActiveKernel().consumers;\n }\n\n public static get consumerMiddleware(): ConsumerMiddleware[] {\n return Kernel.getActiveKernel().consumerMiddleware;\n }\n\n public static get di(): DependencyInjection {\n return Kernel.getActiveKernel().di;\n }\n\n public static get logger(): KernelLogger {\n return Kernel.getActiveKernel().logger;\n }\n\n public static get active(): Kernel {\n return Kernel.getActiveKernel();\n }\n\n public static get rootDirectory(): string {\n return process.cwd();\n }\n\n public static get routes(): ServiceClass<Route>[] {\n return Kernel.getActiveKernel().routes;\n }\n\n public static get schedulers(): Scheduler[] {\n return Kernel.getActiveKernel().schedulers;\n }\n\n public static get sourceDirectory(): string {\n return path.resolve(Kernel.rootDirectory, 'src');\n }\n\n private static getActiveKernel(): Kernel {\n if (!Kernel.state.activeKernel) {\n Kernel.state.activeKernel = new Kernel();\n }\n\n return Kernel.state.activeKernel;\n }\n\n constructor(private readonly options: KernelOptions = {}) {\n this.loggerInstance = options.logger ?? new ConsoleKernelLogger();\n this.dependencyInjectionInstance = options.di;\n Kernel.state.activeKernel = this;\n }\n\n private async closeCandidate(candidate: ShutdownCandidate): Promise<void> {\n if (candidate.shutdown) {\n await candidate.shutdown();\n\n return;\n }\n\n if (candidate.close) {\n await candidate.close();\n\n return;\n }\n\n if (candidate.stop) {\n await candidate.stop();\n\n return;\n }\n\n if (candidate.flush) {\n await candidate.flush();\n }\n }\n\n private getConsumerFromClass(\n ClassDefinition: ServiceClass<Consumer>,\n ): Consumer {\n return this.di.getService<Consumer>(ClassDefinition);\n }\n\n private getInitializerFromClass(\n ClassDefinition: ServiceClass<Initializer>,\n ): Initializer {\n return this.di.getService<Initializer>(ClassDefinition);\n }\n\n private getRuntimeFromClass(ClassDefinition: ServiceClass<Runtime>): Runtime {\n return this.di.getService<Runtime>(ClassDefinition);\n }\n\n private getSchedulerFromClass(\n ClassDefinition: ServiceClass<Scheduler>,\n ): Scheduler {\n return this.di.getService<Scheduler>(ClassDefinition);\n }\n\n public get consumers(): Consumer[] {\n return this.consumersList;\n }\n\n public get consumerMiddleware(): ConsumerMiddleware[] {\n return this.consumerMiddlewares;\n }\n\n public get di(): DependencyInjection {\n if (!this.dependencyInjectionInstance) {\n throw new Error('Kernel dependency injection has not been initialized.');\n }\n\n return this.dependencyInjectionInstance;\n }\n\n public get logger(): KernelLogger {\n return this.loggerInstance;\n }\n\n public get routes(): ServiceClass<Route>[] {\n return this.routesList;\n }\n\n public get schedulers(): Scheduler[] {\n return this.schedulersList;\n }\n\n private getDependencyInjectionOptions(\n options: KernelDependencyInjectionOptions = {},\n ): Required<KernelDependencyInjectionOptions> {\n return {\n containerBuild:\n options.containerBuild ?? process.env.CONTAINER_BUILD === 'true',\n overrides: options.overrides ?? [],\n servicesYamlPath:\n options.servicesYamlPath ??\n this.options.servicesYamlPath ??\n path.resolve(Kernel.configDirectory, 'container', 'services.yaml'),\n sourceDirectory:\n options.sourceDirectory ??\n this.options.sourceDirectory ??\n Kernel.sourceDirectory,\n };\n }\n\n public async dependencyInjection(\n options: KernelDependencyInjectionOptions = {},\n ): Promise<void> {\n Kernel.state.activeKernel = this;\n this.dependencyInjectionInstance =\n this.dependencyInjectionInstance ??\n DependencyInjection.configure(\n this.getDependencyInjectionOptions(options),\n );\n\n await this.dependencyInjectionInstance.compile();\n Kernel.state.activeKernel = this;\n }\n\n public getRoutes(): ServiceClass<Route>[] {\n return this.routes;\n }\n\n public registerConsumerMiddleware(\n ...middlewares: ConsumerMiddleware[]\n ): void {\n this.consumerMiddlewares.push(...middlewares);\n }\n\n public registerConsumers(\n ...ClassDefinitions: ServiceClass<Consumer>[]\n ): void {\n for (const ClassDefinition of ClassDefinitions) {\n this.consumersList.push(this.getConsumerFromClass(ClassDefinition));\n }\n }\n\n public registerConsumerInstances(...consumers: Consumer[]): void {\n this.consumersList.push(...consumers);\n }\n\n public registerRoutes(...ClassDefinitions: ServiceClass<Route>[]): void {\n this.routesList.push(...ClassDefinitions);\n }\n\n public registerSchedulers(\n ...ClassDefinitions: ServiceClass<Scheduler>[]\n ): void {\n for (const ClassDefinition of ClassDefinitions) {\n this.schedulersList.push(this.getSchedulerFromClass(ClassDefinition));\n }\n }\n\n public registerSchedulerInstances(...schedulers: Scheduler[]): void {\n this.schedulersList.push(...schedulers);\n }\n\n public registerShutdownHook(hook: ShutdownHook): void {\n this.shutdownHooks.push(hook);\n }\n\n public removeConsumers(): void {\n this.consumersList.length = 0;\n }\n\n public removeRoutes(): void {\n this.routesList.length = 0;\n }\n\n public removeSchedulers(): void {\n this.schedulersList.length = 0;\n }\n\n public async runConsumers(): Promise<void> {\n for (const consumer of this.consumersList) {\n await consumer.init();\n }\n }\n\n public async runInitializers(\n ...ClassDefinitions: ServiceClass<Initializer>[]\n ): Promise<void> {\n for (const ClassDefinition of ClassDefinitions) {\n await this.getInitializerFromClass(ClassDefinition).ensure();\n }\n }\n\n public async runRuntimes(\n ...ClassDefinitions: ServiceClass<Runtime>[]\n ): Promise<void> {\n for (const ClassDefinition of ClassDefinitions) {\n const runtime = this.getRuntimeFromClass(ClassDefinition);\n\n await runtime.run();\n this.registerShutdownHook(() =>\n this.closeCandidate(runtime as ShutdownCandidate),\n );\n }\n }\n\n public async runSchedulerNowAndSchedule(\n ClassDefinition: ServiceClass<Scheduler>,\n ): Promise<void> {\n const scheduler = this.getSchedulerFromClass(ClassDefinition);\n\n await scheduler.runOnce();\n await scheduler.init();\n this.schedulersList.push(scheduler);\n }\n\n public async runSchedulers(): Promise<void> {\n for (const scheduler of this.schedulersList) {\n await scheduler.init();\n }\n }\n\n public async shutdown(): Promise<void> {\n for (const consumer of [...this.consumersList].reverse()) {\n await this.closeCandidate(consumer as ShutdownCandidate);\n }\n\n for (const scheduler of [...this.schedulersList].reverse()) {\n await this.closeCandidate(scheduler as ShutdownCandidate);\n }\n\n for (const hook of [...this.shutdownHooks].reverse()) {\n await hook();\n }\n\n await this.closeCandidate(this.loggerInstance as ShutdownCandidate);\n }\n}\n\nexport function createKernel(options?: KernelOptions): Kernel {\n return new Kernel(options);\n}\n\nexport default Kernel;\n","import fs from 'fs-extra';\nimport {\n Autowire,\n ContainerBuilder,\n ServiceFile,\n YamlFileLoader,\n} from 'node-dependency-injection';\nimport path from 'node:path';\n\nimport type { ServiceResolver } from '../../contracts/index.js';\nimport type { ContainerInternals } from './ContainerInternals.js';\nimport type { DefinitionMetadata } from './DefinitionMetadata.js';\nimport type { DependencyInjectionOptions } from './DependencyInjectionOptions.js';\nimport type { DependencyOverride } from './DependencyOverride.js';\n\nexport class DependencyInjection implements ServiceResolver {\n private static configuredInstance: DependencyInjection | undefined;\n private autowire: Autowire | undefined;\n private loader: YamlFileLoader | undefined;\n private readonly container: ContainerBuilder;\n private readonly overrideTokenIds = new Map<unknown, string>();\n\n public static configure(\n options: DependencyInjectionOptions,\n ): DependencyInjection {\n DependencyInjection.configuredInstance = new DependencyInjection(options);\n\n return DependencyInjection.configuredInstance;\n }\n\n public static get instance(): DependencyInjection {\n if (!DependencyInjection.configuredInstance) {\n throw new Error('DependencyInjection has not been configured.');\n }\n\n return DependencyInjection.configuredInstance;\n }\n\n constructor(\n private readonly options: DependencyInjectionOptions = {\n containerBuild: process.env.CONTAINER_BUILD === 'true',\n servicesYamlPath: path.resolve(\n process.cwd(),\n 'config',\n 'container',\n 'services.yaml',\n ),\n sourceDirectory: path.resolve(process.cwd(), 'src'),\n },\n ) {\n this.container = new ContainerBuilder(false, this.options.sourceDirectory);\n }\n\n private get definitions(): Map<string, DefinitionMetadata> {\n const container = this.container as unknown as ContainerInternals;\n\n return container._definitions || new Map();\n }\n\n private get aliases(): Map<string, string> {\n const container = this.container as unknown as ContainerInternals;\n\n return container._alias || new Map();\n }\n\n private async ensureFolderExists(filePath: string): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n }\n\n private getServiceClassName(serviceName: unknown): string | undefined {\n return typeof serviceName === 'function' ? serviceName.name : undefined;\n }\n\n private getOverrideId(prefix: string, token: unknown): string {\n const tokenName = this.getServiceClassName(token) ?? String(token);\n\n return `ddd-kernel.override.${prefix}.${tokenName}`;\n }\n\n private ensureSyntheticService(id: string, value: unknown): void {\n const definition = this.container.register(id);\n\n definition.public = true;\n definition.synthetic = true;\n this.container.set(id, value);\n }\n\n private parentMatchesService(\n parentId: string | null | undefined,\n serviceClassName: string,\n ): boolean {\n if (!parentId) {\n return false;\n }\n\n const parentName = Buffer.from(parentId, 'base64').toString('utf8');\n\n return parentName.endsWith(`__${serviceClassName}__${serviceClassName}`);\n }\n\n private serviceIdMatchesService(\n serviceId: string,\n serviceClassName: string,\n ): boolean {\n const serviceName = Buffer.from(serviceId, 'base64').toString('utf8');\n\n return serviceName.endsWith(`__${serviceClassName}__${serviceClassName}`);\n }\n\n private serviceIdReferencesService(\n serviceId: string,\n serviceClassName: string,\n ): boolean {\n const serviceName = Buffer.from(serviceId, 'base64').toString('utf8');\n\n return serviceName.endsWith(`__${serviceClassName}`);\n }\n\n private getReferenceId(value: unknown): string | undefined {\n if (\n typeof value === 'object' &&\n value !== null &&\n 'id' in value &&\n typeof value.id === 'string'\n ) {\n return value.id;\n }\n\n return undefined;\n }\n\n private getDefinitionArgumentReferences(\n definition: DefinitionMetadata,\n ): string[] {\n return [\n ...(definition._args ?? []),\n ...(definition._appendArgs ?? []),\n ...(definition._overrideArgs ?? []),\n ].flatMap((argument) => {\n const referenceId = this.getReferenceId(argument);\n\n return referenceId ? [referenceId] : [];\n });\n }\n\n private findConcreteChildServiceId(serviceName: unknown): string | undefined {\n const serviceClassName = this.getServiceClassName(serviceName);\n\n if (!serviceClassName) {\n return undefined;\n }\n\n const matches = [...this.definitions.entries()]\n .filter(([, definition]) => definition._abstract !== true)\n .filter(([, definition]) =>\n this.parentMatchesService(definition._parent, serviceClassName),\n )\n .map(([id]) => id);\n\n return matches[matches.length - 1];\n }\n\n private findRegisteredServiceId(serviceName: unknown): string | undefined {\n const serviceClassName = this.getServiceClassName(serviceName);\n\n if (!serviceClassName) {\n return undefined;\n }\n\n const matches = [...this.definitions.keys()].filter((id) =>\n this.serviceIdMatchesService(id, serviceClassName),\n );\n\n return matches[matches.length - 1];\n }\n\n private findAliasServiceId(serviceName: unknown): string | undefined {\n const serviceClassName = this.getServiceClassName(serviceName);\n\n if (!serviceClassName) {\n return undefined;\n }\n\n const matches = [...this.aliases.keys()].filter((id) =>\n this.serviceIdMatchesService(id, serviceClassName),\n );\n\n return matches[matches.length - 1];\n }\n\n private findReferencedServiceIds(serviceName: unknown): string[] {\n const serviceClassName = this.getServiceClassName(serviceName);\n\n if (!serviceClassName) {\n return [];\n }\n\n return [\n ...new Set(\n [...this.definitions.values()]\n .flatMap((definition) =>\n this.getDefinitionArgumentReferences(definition),\n )\n .filter((id) =>\n this.serviceIdReferencesService(id, serviceClassName),\n ),\n ),\n ];\n }\n\n private getOverrideTokenIds(token: unknown): string[] {\n const tokenIds = [\n this.findRegisteredServiceId(token),\n this.findAliasServiceId(token),\n ...this.findReferencedServiceIds(token),\n ].filter((id): id is string => id !== undefined);\n const existingTokenIds = [...new Set(tokenIds)];\n\n if (existingTokenIds.length > 0) {\n return existingTokenIds;\n }\n\n const overrideTokenId = this.getOverrideId('token', token);\n\n this.ensureSyntheticService(overrideTokenId, undefined);\n\n return [overrideTokenId];\n }\n\n private getOverrideClassServiceId(\n ClassDefinition: new () => unknown,\n ): string {\n const registeredServiceId = this.findRegisteredServiceId(ClassDefinition);\n\n if (registeredServiceId) {\n return registeredServiceId;\n }\n\n const overrideClassId = this.getOverrideId('class', ClassDefinition);\n\n this.container.register(overrideClassId, ClassDefinition);\n\n return overrideClassId;\n }\n\n private applyClassOverride(override: DependencyOverride): void {\n if (!('useClass' in override)) {\n return;\n }\n\n const tokenIds = this.getOverrideTokenIds(override.token);\n const classId = this.getOverrideClassServiceId(override.useClass);\n\n this.overrideTokenIds.set(override.token, tokenIds[0]);\n for (const tokenId of tokenIds) {\n this.container.setAlias(tokenId, classId);\n }\n }\n\n private applyFactoryOverride(override: DependencyOverride): void {\n if (!('useFactory' in override)) {\n return;\n }\n\n const tokenIds = this.getOverrideTokenIds(override.token);\n const factoryId = this.getOverrideId('factory', override.token);\n\n this.ensureSyntheticService(factoryId, override.useFactory(this));\n this.overrideTokenIds.set(override.token, tokenIds[0]);\n for (const tokenId of tokenIds) {\n this.container.setAlias(tokenId, factoryId);\n }\n }\n\n private applyValueOverride(override: DependencyOverride): void {\n if (!('useValue' in override)) {\n return;\n }\n\n const tokenIds = this.getOverrideTokenIds(override.token);\n const valueId = this.getOverrideId('value', override.token);\n\n this.ensureSyntheticService(valueId, override.useValue);\n this.overrideTokenIds.set(override.token, tokenIds[0]);\n for (const tokenId of tokenIds) {\n this.container.setAlias(tokenId, valueId);\n }\n }\n\n private applyOverrides(): void {\n for (const override of this.options.overrides ?? []) {\n this.applyClassOverride(override);\n this.applyFactoryOverride(override);\n this.applyValueOverride(override);\n }\n }\n\n private registerParentAliases(): void {\n for (const [id, definition] of this.definitions.entries()) {\n if (definition._abstract === true || !definition._parent) {\n continue;\n }\n\n this.container.setAlias(definition._parent, id);\n }\n }\n\n public async compile(): Promise<void> {\n if (this.options.containerBuild) {\n await this.ensureFolderExists(this.options.servicesYamlPath);\n this.autowire = new Autowire(this.container);\n this.autowire.serviceFile = new ServiceFile(\n this.options.servicesYamlPath,\n false,\n );\n await this.autowire.process();\n } else {\n this.loader = new YamlFileLoader(this.container);\n await this.loader.load(this.options.servicesYamlPath);\n }\n\n this.registerParentAliases();\n this.applyOverrides();\n await this.container.compile();\n }\n\n public getService<T>(serviceName: unknown): T {\n const overrideTokenId = this.overrideTokenIds.get(serviceName);\n\n if (overrideTokenId) {\n return this.container.get<T>(overrideTokenId);\n }\n\n const aliasServiceId = this.findAliasServiceId(serviceName);\n\n if (aliasServiceId) {\n return this.container.get<T>(aliasServiceId);\n }\n\n const childServiceId = this.findConcreteChildServiceId(serviceName);\n\n if (childServiceId) {\n return this.container.get<T>(childServiceId);\n }\n\n const registeredServiceId = this.findRegisteredServiceId(serviceName);\n\n if (registeredServiceId) {\n return this.container.get<T>(registeredServiceId);\n }\n\n return this.container.get<T>(serviceName);\n }\n}\n\nexport default DependencyInjection;\n","import type {\n ConsumerExecutionContext,\n ConsumerMiddleware,\n} from '../../contracts/index.js';\nimport type { DomainEvent } from '../../domain/index.js';\n\nexport class ConsumerMiddlewarePipeline {\n constructor(private readonly middlewares: readonly ConsumerMiddleware[]) {}\n\n private async run(\n event: DomainEvent,\n context: ConsumerExecutionContext,\n handler: () => Promise<void>,\n index: number,\n ): Promise<void> {\n const middleware = this.middlewares[index];\n\n if (!middleware) {\n await handler();\n\n return;\n }\n\n await middleware.handle(\n event,\n () => this.run(event, context, handler, index + 1),\n context,\n );\n }\n\n public async execute(\n event: DomainEvent,\n context: ConsumerExecutionContext,\n handler: () => Promise<void>,\n ): Promise<void> {\n await this.run(event, context, handler, 0);\n }\n}\n","import type { DomainEventConsumer } from '../../domain/DomainEventConsumer.js';\nimport type {\n DomainEvent,\n DomainEventConsumerContext,\n} from '../../domain/index.js';\n\nimport { Kernel } from '../../Kernel.js';\nimport { ConsumerMiddlewarePipeline } from './ConsumerMiddlewarePipeline.js';\n\nexport abstract class Consumer {\n constructor(private readonly consumer: DomainEventConsumer) {}\n\n private async runMiddleware(\n event: DomainEvent,\n consumerContext?: DomainEventConsumerContext,\n ): Promise<void> {\n const pipeline = new ConsumerMiddlewarePipeline(Kernel.consumerMiddleware);\n const metadata = consumerContext?.metadata ?? {};\n\n await pipeline.execute(\n event,\n {\n causationId: event.getCausationId(),\n correlationId: event.getCorrelationId(),\n eventId: event.eventId,\n eventName: this.eventName,\n exchange: this.exchange,\n kernel: Kernel.active,\n metadata,\n queueName: this.queueName,\n rawMessage: metadata.rawMessage,\n },\n () => this.handler(event),\n );\n }\n\n public abstract get domainEvent(): typeof DomainEvent;\n\n public abstract get eventName(): string;\n\n public abstract get exchange(): string;\n\n public abstract get queueName(): string;\n\n public abstract handler(event: DomainEvent): Promise<void>;\n\n public async init(): Promise<void> {\n await this.consumer.consume(\n this.queueName,\n this.eventName,\n this.domainEvent,\n this.exchange,\n (event, context) => this.runMiddleware(event, context),\n );\n }\n\n public get<T>(service: unknown): T {\n return Kernel.di.getService<T>(service);\n }\n}\n\nexport default Consumer;\n","import type {\n ConsumerExecutionContext,\n ConsumerMiddleware,\n ConsumerNext,\n} from '../../contracts/index.js';\nimport type { DomainEvent } from '../../domain/index.js';\nimport type { CorrelationConsumerMiddlewareOptions } from './CorrelationConsumerMiddlewareOptions.js';\n\nexport class CorrelationConsumerMiddleware implements ConsumerMiddleware {\n constructor(\n private readonly options: CorrelationConsumerMiddlewareOptions = {},\n ) {}\n\n public async handle(\n event: DomainEvent,\n next: ConsumerNext,\n context: ConsumerExecutionContext,\n ): Promise<void> {\n const correlationId =\n this.options.correlationId?.(event, context) ?? context.correlationId;\n const causationId =\n this.options.causationId?.(event, context) ?? context.causationId;\n\n if (correlationId) {\n event.withCorrelationId(correlationId);\n }\n\n if (causationId) {\n event.withCausationId(causationId);\n }\n\n await next();\n }\n}\n\nexport default CorrelationConsumerMiddleware;\n","import type {\n PublishContext,\n PublisherHookErrorPolicy,\n} from '../../contracts/index.js';\n\nexport class DefaultPublisherHookErrorPolicy implements PublisherHookErrorPolicy {\n public handleAfterPublishError(\n error: unknown,\n context: PublishContext,\n ): void {\n void error;\n void context;\n }\n\n public shouldFailAfterPublish(\n error: unknown,\n context: PublishContext,\n ): boolean {\n void error;\n void context;\n\n return false;\n }\n}\n\nexport default DefaultPublisherHookErrorPolicy;\n","import type {\n ConsumerExecutionContext,\n ConsumerMiddleware,\n ConsumerNext,\n} from '../../contracts/index.js';\nimport type { DomainEvent } from '../../domain/index.js';\nimport type { IdempotencyConsumerMiddlewareOptions } from './IdempotencyConsumerMiddlewareOptions.js';\n\nexport class IdempotencyConsumerMiddleware implements ConsumerMiddleware {\n constructor(private readonly options: IdempotencyConsumerMiddlewareOptions) {}\n\n private async handleClaimedKey(\n key: string,\n next: ConsumerNext,\n ): Promise<void> {\n const claimed = await this.options.store.claim?.(key);\n\n if (!claimed) {\n return;\n }\n\n try {\n await next();\n await (this.options.store.commit?.(key) ?? this.options.store.mark(key));\n } catch (error: unknown) {\n await this.options.store.release?.(key);\n\n throw error;\n }\n }\n\n private async handleLegacyKey(\n key: string,\n next: ConsumerNext,\n ): Promise<void> {\n if (await this.options.store.has(key)) {\n return;\n }\n\n await next();\n await this.options.store.mark(key);\n }\n\n public async handle(\n event: DomainEvent,\n next: ConsumerNext,\n context: ConsumerExecutionContext,\n ): Promise<void> {\n const key = this.options.key?.(event, context) ?? context.eventId;\n\n if (this.options.store.claim) {\n await this.handleClaimedKey(key, next);\n } else {\n await this.handleLegacyKey(key, next);\n }\n }\n}\n\nexport default IdempotencyConsumerMiddleware;\n","import type { IdempotencyStore } from '../../contracts/index.js';\n\nexport class InMemoryIdempotencyStore implements IdempotencyStore {\n private readonly claimedKeys = new Set<string>();\n private readonly handledKeys = new Set<string>();\n\n public claim(key: string): boolean {\n if (this.handledKeys.has(key) || this.claimedKeys.has(key)) {\n return false;\n }\n\n this.claimedKeys.add(key);\n\n return true;\n }\n\n public commit(key: string): void {\n this.claimedKeys.delete(key);\n this.handledKeys.add(key);\n }\n\n public release(key: string): void {\n this.claimedKeys.delete(key);\n }\n\n public has(key: string): boolean {\n return this.handledKeys.has(key);\n }\n\n public mark(key: string): void {\n this.handledKeys.add(key);\n }\n}\n\nexport default InMemoryIdempotencyStore;\n","import type {\n PublishContext,\n PublisherHook,\n PublisherHookErrorPolicy,\n} from '../../contracts/index.js';\n\nimport { DefaultPublisherHookErrorPolicy } from './DefaultPublisherHookErrorPolicy.js';\n\nexport class PublisherHookPipeline {\n private readonly hooks: PublisherHook[] = [];\n\n constructor(\n hooks: readonly PublisherHook[] = [],\n private readonly errorPolicy: PublisherHookErrorPolicy = new DefaultPublisherHookErrorPolicy(),\n ) {\n this.hooks.push(...hooks);\n }\n\n private async runAfterPublishHooks(context: PublishContext): Promise<void> {\n for (const hook of this.hooks) {\n await this.runAfterPublishHook(hook, context);\n }\n }\n\n private async runAfterPublishHook(\n hook: PublisherHook,\n context: PublishContext,\n ): Promise<void> {\n try {\n await hook.afterPublish?.(context);\n } catch (error: unknown) {\n await this.errorPolicy.handleAfterPublishError(error, context);\n\n if (this.errorPolicy.shouldFailAfterPublish(error, context)) {\n throw error;\n }\n }\n }\n\n private async runBeforePublishHooks(context: PublishContext): Promise<void> {\n for (const hook of this.hooks) {\n await hook.beforePublish?.(context);\n }\n }\n\n private async runPublishErrorHooks(\n error: unknown,\n context: PublishContext,\n ): Promise<void> {\n for (const hook of this.hooks) {\n await hook.onPublishError?.(error, context);\n }\n }\n\n public register(...hooks: PublisherHook[]): void {\n this.hooks.push(...hooks);\n }\n\n public async run<T>(\n context: PublishContext,\n publish: () => Promise<T> | T,\n ): Promise<T> {\n await this.runBeforePublishHooks(context);\n\n try {\n const result = await publish();\n\n await this.runAfterPublishHooks(context);\n\n return result;\n } catch (error: unknown) {\n await this.runPublishErrorHooks(error, context);\n\n throw error;\n }\n }\n}\n","import type {\n ConsumerExecutionContext,\n ConsumerMiddleware,\n ConsumerNext,\n} from '../../contracts/index.js';\nimport type { DomainEvent } from '../../domain/index.js';\nimport type { RetryConsumerMiddlewareOptions } from './RetryConsumerMiddlewareOptions.js';\n\nexport class RetryConsumerMiddleware implements ConsumerMiddleware {\n constructor(private readonly options: RetryConsumerMiddlewareOptions) {}\n\n private async delay(\n attempt: number,\n error: unknown,\n context: ConsumerExecutionContext,\n ): Promise<void> {\n const delayInMilliseconds =\n typeof this.options.delay === 'function'\n ? await this.options.delay(attempt, error, context)\n : (this.options.delay ?? 0);\n\n if (delayInMilliseconds > 0) {\n await new Promise((resolve) => setTimeout(resolve, delayInMilliseconds));\n }\n }\n\n public async handle(\n event: DomainEvent,\n next: ConsumerNext,\n context: ConsumerExecutionContext,\n ): Promise<void> {\n for (let attempt = 1; attempt <= this.options.maxAttempts; attempt++) {\n try {\n await next();\n\n return;\n } catch (error: unknown) {\n const canRetry =\n attempt < this.options.maxAttempts &&\n (await (this.options.shouldRetry?.(error, attempt, context) ?? true));\n\n if (!canRetry) {\n throw error;\n }\n\n await this.options.onRetry?.(error, attempt, context);\n await this.delay(attempt, error, context);\n }\n }\n }\n}\n\nexport default RetryConsumerMiddleware;\n","import amqplib, {\n type Channel,\n type ChannelModel,\n type ConsumeMessage,\n type GetMessage,\n type MessagePropertyHeaders,\n type Options,\n} from 'amqplib';\nimport { randomUUID } from 'node:crypto';\n\nimport type { PublisherHook } from '../../../contracts/index.js';\nimport type {\n Constructor,\n DomainEvent,\n DomainEventConsumer,\n DomainEventConsumerContext,\n DomainMessageBus,\n DomainEventPublisher,\n} from '../../../domain/index.js';\nimport type { AmqpMessage } from './AmqpMessage.js';\nimport type { AmqpMessageBusAdapterOptions } from './AmqpMessageBusAdapterOptions.js';\nimport type { ConsumerContext } from './ConsumerContext.js';\nimport type { DomainEventHandler } from './DomainEventHandler.js';\n\nimport { Kernel } from '../../../Kernel.js';\nimport { PublisherHookPipeline } from '../PublisherHookPipeline.js';\nimport { InvalidDomainEventError } from './InvalidDomainEventError.js';\nimport { NoFailedMessagesError } from './NoFailedMessagesError.js';\n\nexport default class AmqpMessageBusAdapter\n implements DomainEventConsumer, DomainEventPublisher, DomainMessageBus\n{\n private channelInstance: Channel | undefined;\n private connection: ChannelModel | undefined;\n private readonly delayConsumers: string[] = [];\n private exchange: string;\n private readonly publisherHookPipeline: PublisherHookPipeline;\n\n constructor(private readonly options: AmqpMessageBusAdapterOptions = {}) {\n this.exchange =\n options.exchange ?? options.serviceName ?? process.env.SERVICE_NAME ?? '';\n this.publisherHookPipeline = new PublisherHookPipeline(\n options.publisherHooks,\n options.publisherHookErrorPolicy,\n );\n }\n\n private get dsn(): string {\n return this.options.dsn ?? process.env.TRANSPORT_DSN ?? '';\n }\n\n private get logger(): AmqpMessageBusAdapterOptions['logger'] {\n return this.options.logger ?? Kernel.logger;\n }\n\n private get maxRetries(): number | undefined {\n const configuredRetries =\n this.options.maxRetries ?? process.env.TRANSPORT_MAX_RETRIES;\n\n if (configuredRetries === undefined) {\n return undefined;\n }\n\n return Number(configuredRetries);\n }\n\n private get retryDelayInMilliseconds(): number {\n const retryDelayFromEnv = Number(process.env.TRANSPORT_RETRY_DELAY);\n\n return (\n this.options.retryDelayInMilliseconds ??\n (Number.isFinite(retryDelayFromEnv) ? retryDelayFromEnv : 1000)\n );\n }\n\n private instanceDomainEvent(\n DomainEventInstance: Constructor<DomainEvent>,\n message: AmqpMessage,\n ): DomainEvent {\n if (!message) {\n throw new InvalidDomainEventError(JSON.stringify(message));\n }\n\n return new DomainEventInstance(\n message.aggregate_id,\n message.attributes,\n message.event_id,\n message.occurred_on ? new Date(message.occurred_on) : new Date(),\n message.correlation_id,\n message.causation_id,\n );\n }\n\n private getConsumerContext(\n msg: ConsumeMessage | GetMessage,\n ): DomainEventConsumerContext {\n return {\n metadata: {\n headers: msg.properties.headers ?? {},\n rawMessage: msg,\n retries: Number(msg.properties.headers?.retries ?? 0),\n },\n };\n }\n\n private async handle(\n msg: ConsumeMessage,\n context: ConsumerContext,\n ): Promise<void> {\n const message = JSON.parse(msg.content.toString()) as AmqpMessage;\n\n this.logger?.info(\n `AMQP message bus (${context.queueName}) handling message: ${JSON.stringify(message)}`,\n );\n\n try {\n const domainEvent = this.instanceDomainEvent(\n context.DomainEventInstance,\n message,\n );\n\n await context.handler(domainEvent, this.getConsumerContext(msg));\n } catch (error) {\n await this.handleError(msg, message, context, error);\n }\n }\n\n private async handleError(\n msg: ConsumeMessage,\n message: AmqpMessage,\n context: ConsumerContext,\n error: unknown,\n ): Promise<void> {\n this.logger?.error(error instanceof Error ? error.message : String(error));\n const headers = msg.properties.headers ?? {};\n const retryCount = Number(headers.retries ?? 0);\n\n if (this.maxRetries !== undefined && retryCount <= this.maxRetries) {\n await this.retry(message, headers, context);\n\n return;\n }\n\n await this.sendToDlx(message, context, String(error));\n }\n\n private async retry(\n message: AmqpMessage,\n headers: MessagePropertyHeaders,\n context: ConsumerContext,\n ): Promise<void> {\n const retry = Number(headers.retries || 1);\n const delayTimeInMs = retry * this.retryDelayInMilliseconds;\n const delayedQueueName = `${context.queueName}_delayed_${delayTimeInMs}`;\n const delayedRoutingKey = `${context.queueName}_${context.bindingKey}_delayed_${delayTimeInMs}`;\n const consumerTag = `${delayedQueueName}_${randomUUID()}`;\n\n this.logger?.info(`Retry # ${retry}`);\n\n if (!this.delayConsumers.includes(delayedQueueName)) {\n await this.registerDelayedConsumer(\n delayedQueueName,\n delayedRoutingKey,\n delayTimeInMs,\n consumerTag,\n context,\n );\n }\n\n try {\n const domainEvent = this.instanceDomainEvent(\n context.DomainEventInstance,\n message,\n );\n\n context.channel.publish(\n this.exchange,\n delayedRoutingKey,\n Buffer.from(JSON.stringify(message)),\n this.opts(domainEvent, retry),\n );\n } catch (error: unknown) {\n await context.channel.cancel(consumerTag);\n this.logger?.error(\n error instanceof Error ? error.message : String(error),\n );\n }\n }\n\n private async registerDelayedConsumer(\n delayedQueueName: string,\n delayedRoutingKey: string,\n delayTimeInMs: number,\n consumerTag: string,\n context: ConsumerContext,\n ): Promise<void> {\n await context.channel.assertExchange(this.exchange, 'topic', {\n durable: true,\n });\n await context.channel.assertQueue(delayedQueueName, {\n autoDelete: true,\n deadLetterExchange: this.exchange,\n deadLetterRoutingKey: delayedRoutingKey,\n durable: false,\n messageTtl: delayTimeInMs,\n });\n await context.channel.bindQueue(\n delayedQueueName,\n this.exchange,\n delayedRoutingKey,\n );\n this.delayConsumers.push(delayedQueueName);\n await context.channel.consume(\n delayedQueueName,\n async (msg: ConsumeMessage | null) => {\n if (!msg) {\n return;\n }\n\n await new Promise((resolve) => setTimeout(resolve, delayTimeInMs));\n await this.handle(msg, context);\n this.removeDelayConsumer(delayedQueueName);\n await context.channel.cancel(consumerTag);\n },\n { consumerTag, noAck: true },\n );\n }\n\n private removeDelayConsumer(delayedQueueName: string): void {\n const index = this.delayConsumers.indexOf(delayedQueueName);\n\n if (index !== -1) {\n this.delayConsumers.splice(index, 1);\n }\n }\n\n private async sendToDlx(\n message: AmqpMessage,\n context: ConsumerContext,\n error?: string,\n ): Promise<void> {\n await context.channel.assertExchange(this.exchange, 'topic');\n const dlxQueueName = `${context.queueName}_dlx`;\n const dlxRoutingKey = `${context.queueName}_${context.bindingKey}_dlx`;\n\n await context.channel.assertQueue(dlxQueueName, {\n deadLetterExchange: this.exchange,\n deadLetterRoutingKey: dlxRoutingKey,\n durable: true,\n });\n await context.channel.bindQueue(dlxQueueName, this.exchange, dlxRoutingKey);\n\n try {\n const domainEvent = this.instanceDomainEvent(\n context.DomainEventInstance,\n message,\n );\n\n context.channel.publish(\n this.exchange,\n dlxRoutingKey,\n Buffer.from(JSON.stringify(message)),\n this.opts(domainEvent, message.retries, error),\n );\n } catch (publishError: unknown) {\n this.logger?.error(\n publishError instanceof Error\n ? publishError.message\n : String(publishError),\n );\n }\n }\n\n private async connect(): Promise<void> {\n this.connection = await amqplib.connect(this.getConnectionDsn());\n this.channelInstance = await this.connection.createChannel();\n this.channelInstance\n .on('close', async () => {\n this.logger?.error('AMQP message bus event close');\n await this.reconnect();\n })\n .on('error', async (error) => {\n this.logger?.error(`AMQP message bus event error: ${error.message}`);\n await this.reconnect();\n });\n }\n\n private async reconnect(): Promise<void> {\n await this.connect();\n\n for (const consumer of Kernel.consumers) {\n await consumer.init();\n }\n }\n\n private async channel(forceNew = false): Promise<Channel> {\n if (forceNew) {\n const connection = await amqplib.connect(this.getConnectionDsn());\n\n return connection.createChannel();\n }\n\n if (!this.channelInstance) {\n await this.connect();\n }\n\n if (!this.channelInstance) {\n throw new Error('AMQP channel could not be created.');\n }\n\n await this.channelInstance.assertExchange(this.exchange, 'topic', {\n durable: true,\n });\n\n return this.channelInstance;\n }\n\n private getConnectionDsn(): string {\n const separator = this.dsn.includes('?') ? '&' : '?';\n\n return `${this.dsn}${separator}heartbeat=60`;\n }\n\n private opts(\n event: DomainEvent,\n retries?: number,\n error?: string,\n ): Options.Publish {\n return {\n appId: this.options.serviceName ?? process.env.SERVICE_NAME,\n contentEncoding: 'utf-8',\n contentType: 'application/json',\n deliveryMode: 2,\n headers: {\n error,\n retries: retries ? retries + 1 : 0,\n },\n messageId: event.eventId,\n priority: 0,\n timestamp: event.occurredOn.getTime(),\n type: event.eventName(),\n };\n }\n\n private getMessagesToRetry(\n requestedMessagesToRetry: number | undefined,\n availableMessages: number,\n ): number {\n return requestedMessagesToRetry ?? availableMessages;\n }\n\n private async retryDlxMessage(\n msg: ConsumeMessage | GetMessage,\n DomainEventInstance: Constructor<DomainEvent>,\n handler: DomainEventHandler,\n channel: Channel,\n ): Promise<void> {\n const content = msg.content.toString();\n\n this.logger?.info(`Retrying message from DLX ${content}`);\n\n try {\n const message = JSON.parse(content) as AmqpMessage;\n const domainEvent = this.instanceDomainEvent(\n DomainEventInstance,\n message,\n );\n\n await handler(domainEvent, this.getConsumerContext(msg));\n this.logger?.info(`${content} successfully handled.`);\n channel.ack(msg);\n } catch (error: Error | unknown) {\n const errorMessage =\n error instanceof Error ? error.message : String(error);\n\n this.logger?.error(`${content} error with ${errorMessage}.`);\n channel.nack(msg);\n }\n }\n\n public async areQueuesBound(): Promise<boolean> {\n if (Kernel.consumers.length === 0) {\n return false;\n }\n\n const channel = await this.channel();\n\n for (const consumer of Kernel.consumers) {\n const queueChecker = await channel.checkQueue(consumer.queueName);\n\n if (queueChecker.consumerCount !== 0) {\n return false;\n }\n }\n\n return true;\n }\n\n public async consumeDlx(\n queueName: string,\n DomainEventInstance: Constructor<DomainEvent>,\n handler: DomainEventHandler,\n messagesToRetry?: number,\n ): Promise<void> {\n const dlxQueueName = `${queueName}_dlx`;\n const channel = await this.channel(true);\n\n channel.on('error', () => {\n this.logger?.error('AMQP message bus event error');\n });\n\n const queue = await channel.checkQueue(dlxQueueName);\n const messagesToRetryCount = this.getMessagesToRetry(\n messagesToRetry,\n queue.messageCount,\n );\n\n this.logger?.info(\n `Retrying ${messagesToRetryCount} messages from DLX ${dlxQueueName}`,\n );\n\n if (messagesToRetryCount > 0 && queue.messageCount !== 0) {\n for (let index = 0; index < messagesToRetryCount; index++) {\n const msg = await channel.get(dlxQueueName);\n\n if (msg === false) {\n continue;\n }\n\n await this.retryDlxMessage(msg, DomainEventInstance, handler, channel);\n }\n\n return;\n }\n\n throw new NoFailedMessagesError(dlxQueueName);\n }\n\n public async consume(\n queueName: string,\n bindingKey: string,\n DomainEventInstance: Constructor<DomainEvent>,\n exchange: string,\n handler: DomainEventHandler,\n ): Promise<void> {\n const channel = await this.channel();\n\n await channel.assertQueue(queueName, { durable: true });\n await channel.assertExchange(exchange, 'topic');\n await channel.prefetch(1);\n await channel.bindQueue(queueName, exchange, bindingKey);\n\n const context: ConsumerContext = {\n bindingKey,\n channel,\n DomainEventInstance,\n handler,\n queueName,\n };\n\n await channel.consume(queueName, async (msg: ConsumeMessage | null) => {\n if (!msg) {\n return;\n }\n\n await this.handle(msg, context);\n channel.ack(msg);\n });\n }\n\n public async publish(domainEvents: DomainEvent[]): Promise<void> {\n const channel = await this.channel();\n\n for (const event of domainEvents) {\n await this.publisherHookPipeline.run(\n {\n domainEvent: event,\n message: {\n metadata: {\n causationId: event.getCausationId(),\n correlationId: event.getCorrelationId(),\n eventId: event.eventId,\n },\n name: event.eventName(),\n payload: event.attributes,\n },\n metadata: {\n eventId: event.eventId,\n exchange: this.exchange,\n },\n topic: event.eventName(),\n },\n () =>\n channel.publish(\n this.exchange,\n event.eventName(),\n Buffer.from(event.decode()),\n this.opts(event),\n ),\n );\n }\n }\n\n public registerPublisherHooks(...hooks: PublisherHook[]): void {\n this.publisherHookPipeline.register(...hooks);\n }\n\n public async close(): Promise<void> {\n await this.channelInstance?.close();\n await this.connection?.close();\n this.channelInstance = undefined;\n this.connection = undefined;\n }\n}\n","export class InvalidDomainEventError extends Error {\n constructor(message: string) {\n super(`Invalid domain event: ${message}`);\n this.name = 'InvalidDomainEventError';\n }\n}\n","export class NoFailedMessagesError extends Error {\n constructor(queueName: string) {\n super(`No failed messages found in \"${queueName}\".`);\n this.name = 'NoFailedMessagesError';\n }\n}\n","import type {\n DomainEvent,\n HandlerContext,\n MessageHandler,\n PublisherHook,\n PublisherHookErrorPolicy,\n} from '../../../contracts/index.js';\n\nimport { PublisherHookPipeline } from '../PublisherHookPipeline.js';\n\nexport class InMemoryEventBus {\n private readonly handlers = new Map<\n string,\n MessageHandler<DomainEvent, void>[]\n >();\n\n private readonly publisherHookPipeline: PublisherHookPipeline;\n\n constructor(\n private readonly context: HandlerContext,\n publisherHooks: readonly PublisherHook[] = [],\n publisherHookErrorPolicy?: PublisherHookErrorPolicy,\n ) {\n this.publisherHookPipeline = new PublisherHookPipeline(\n publisherHooks,\n publisherHookErrorPolicy,\n );\n }\n\n public subscribe<TEvent extends DomainEvent>(\n name: TEvent['name'],\n handler: MessageHandler<TEvent, void>,\n ): void {\n const handlers = this.handlers.get(name) ?? [];\n\n handlers.push(handler as MessageHandler<DomainEvent, void>);\n this.handlers.set(name, handlers);\n }\n\n public async publish<TEvent extends DomainEvent>(\n event: TEvent,\n ): Promise<void> {\n const handlers = this.handlers.get(event.name) ?? [];\n\n await this.publisherHookPipeline.run(\n { message: event, metadata: event.metadata ?? {}, topic: event.name },\n async () => {\n for (const handler of handlers) {\n await handler(event, this.context);\n }\n },\n );\n }\n\n public registerPublisherHooks(...hooks: PublisherHook[]): void {\n this.publisherHookPipeline.register(...hooks);\n }\n}\n","import type {\n HandlerContext,\n Message,\n MessageHandler,\n PublisherHook,\n PublisherHookErrorPolicy,\n Subscription,\n} from '../../../contracts/index.js';\n\nimport { PublisherHookPipeline } from '../PublisherHookPipeline.js';\n\nexport class InMemoryPubSub {\n private readonly consumers = new Map<\n string,\n Set<MessageHandler<Message, void>>\n >();\n\n private readonly publisherHookPipeline: PublisherHookPipeline;\n\n constructor(\n private readonly context: HandlerContext,\n publisherHooks: readonly PublisherHook[] = [],\n publisherHookErrorPolicy?: PublisherHookErrorPolicy,\n ) {\n this.publisherHookPipeline = new PublisherHookPipeline(\n publisherHooks,\n publisherHookErrorPolicy,\n );\n }\n\n public async publish<TMessage extends Message>(\n topic: string,\n message: TMessage,\n ): Promise<void> {\n const consumers = this.consumers.get(topic) ?? new Set();\n\n await this.publisherHookPipeline.run(\n { message, metadata: message.metadata ?? {}, topic },\n async () => {\n for (const consumer of consumers) {\n await consumer(message, this.context);\n }\n },\n );\n }\n\n public subscribe<TMessage extends Message>(\n topic: string,\n consumer: MessageHandler<TMessage, void>,\n ): Promise<Subscription> {\n const consumers =\n this.consumers.get(topic) ?? new Set<MessageHandler<Message, void>>();\n const castConsumer = consumer as MessageHandler<Message, void>;\n\n consumers.add(castConsumer);\n this.consumers.set(topic, consumers);\n\n return Promise.resolve({\n close: () => {\n consumers.delete(castConsumer);\n\n return Promise.resolve();\n },\n });\n }\n\n public registerPublisherHooks(...hooks: PublisherHook[]): void {\n this.publisherHookPipeline.register(...hooks);\n }\n}\n","import type { ErrorRequestHandler, RequestHandler } from 'express';\n\nimport { createRequire } from 'node:module';\nimport path from 'node:path';\n\nimport type { ExpressAppHook } from './ExpressAppHook.js';\nimport type { ExpressController } from './ExpressController.js';\nimport type { ExpressKernelServerOptions } from './ExpressKernelServerOptions.js';\nimport type { ExpressPhaseHook } from './ExpressPhaseHook.js';\nimport type { HttpApp } from './HttpApp.js';\nimport type { HttpServer } from './HttpServer.js';\n\nexport class ExpressKernelServer {\n private readonly applicationRequire = createRequire(\n path.resolve(process.cwd(), 'package.json'),\n );\n\n private readonly afterControllersHooks: ExpressAppHook[];\n\n private appInstance: HttpApp | undefined;\n\n private readonly beforeControllersHooks: ExpressAppHook[];\n\n private readonly controllers: ExpressController[];\n\n private readonly errorHandlers: ErrorRequestHandler[];\n\n private readonly hooks: ExpressPhaseHook[];\n\n private readonly middlewares: RequestHandler[];\n\n private readonly postControllerMiddlewares: RequestHandler[];\n\n private readonly preControllerMiddlewares: RequestHandler[];\n\n private serverInstance: HttpServer | undefined;\n\n private readonly staticHooks: ExpressAppHook[];\n\n private readonly swaggerHooks: ExpressAppHook[];\n\n constructor(private readonly options: ExpressKernelServerOptions) {\n this.afterControllersHooks = this.copy(options.afterControllersHooks);\n this.beforeControllersHooks = this.copy(options.beforeControllersHooks);\n this.controllers = this.copy(options.controllers);\n this.errorHandlers = this.copy(options.errorHandlers);\n this.hooks = this.copy(options.hooks);\n this.middlewares = this.copy(options.middlewares);\n this.postControllerMiddlewares = this.copy(\n options.postControllerMiddlewares,\n );\n this.preControllerMiddlewares = this.copy(options.preControllerMiddlewares);\n this.staticHooks = this.copy(options.staticHooks);\n this.swaggerHooks = this.copy(options.swaggerHooks);\n }\n\n private copy<Type>(items: Type[] | undefined): Type[] {\n return [...(items ?? [])];\n }\n\n private configureControllerContainer(): void {\n const { useContainer } = this.getRoutingControllers();\n\n useContainer(\n {\n /* c8 ignore next */\n get: (ClassDefinition: ExpressController) =>\n this.options.kernel.di.getService(ClassDefinition),\n },\n {\n fallback: true,\n fallbackOnErrors: true,\n },\n );\n }\n\n private getExpress(): typeof import('express') {\n return this.applicationRequire('express') as typeof import('express');\n }\n\n private getRoutingControllers(): Pick<\n typeof import('routing-controllers'),\n 'useContainer' | 'useExpressServer'\n > {\n return this.applicationRequire('routing-controllers') as Pick<\n typeof import('routing-controllers'),\n 'useContainer' | 'useExpressServer'\n >;\n }\n\n private applyErrorHandlers(app: HttpApp): void {\n const handlers =\n this.errorHandlers.length > 0\n ? this.errorHandlers\n : [this.defaultErrorHandler()];\n\n for (const handler of handlers) {\n app.use(handler);\n }\n }\n\n private defaultErrorHandler(): ErrorRequestHandler {\n return (error, request, response, next) => {\n void next;\n void request;\n\n response.status(500).json({\n error: error instanceof Error ? error.message : String(error),\n });\n };\n }\n\n private async runHooks(\n hooks: readonly ((app: HttpApp) => Promise<void> | void)[],\n app: HttpApp,\n ): Promise<void> {\n for (const hook of hooks) {\n await hook(app);\n }\n }\n\n private async runPhaseHooks(\n phase: 'afterControllers' | 'beforeControllers' | 'beforeErrors',\n app: HttpApp,\n ): Promise<void> {\n for (const hook of this.hooks) {\n if (hook.phase === phase) {\n await hook.handle(app);\n }\n }\n }\n\n private applyMiddlewares(\n app: HttpApp,\n middlewares: readonly RequestHandler[],\n ): void {\n for (const middleware of middlewares) {\n app.use(middleware);\n }\n }\n\n public get app(): HttpApp {\n if (!this.appInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.appInstance;\n }\n\n public get server(): HttpServer {\n if (!this.serverInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.serverInstance;\n }\n\n private assertServerIsNotRunning(): void {\n if (this.serverInstance) {\n throw new Error('HTTP server is already running.');\n }\n }\n\n public close(): Promise<void> {\n if (!this.serverInstance) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n this.serverInstance?.close((error?: Error) => {\n if (error) {\n reject(error);\n\n return;\n }\n\n this.serverInstance = undefined;\n this.appInstance = undefined;\n resolve();\n });\n });\n }\n\n public registerAfterControllersHooks(\n ...hooks: NonNullable<ExpressKernelServerOptions['afterControllersHooks']>\n ): this {\n this.assertServerIsNotRunning();\n this.afterControllersHooks?.push(...hooks);\n\n return this;\n }\n\n public registerBeforeControllersHooks(\n ...hooks: NonNullable<ExpressKernelServerOptions['beforeControllersHooks']>\n ): this {\n this.assertServerIsNotRunning();\n this.beforeControllersHooks?.push(...hooks);\n\n return this;\n }\n\n public registerControllers(...controllers: ExpressController[]): this {\n this.assertServerIsNotRunning();\n this.controllers.push(...controllers);\n\n return this;\n }\n\n public registerErrorHandlers(...handlers: ErrorRequestHandler[]): this {\n this.assertServerIsNotRunning();\n this.errorHandlers.push(...handlers);\n\n return this;\n }\n\n public registerHooks(...hooks: ExpressPhaseHook[]): this {\n this.assertServerIsNotRunning();\n this.hooks.push(...hooks);\n\n return this;\n }\n\n public registerMiddlewares(...middlewares: RequestHandler[]): this {\n this.assertServerIsNotRunning();\n this.middlewares.push(...middlewares);\n\n return this;\n }\n\n public registerPostControllerMiddlewares(\n ...middlewares: RequestHandler[]\n ): this {\n this.assertServerIsNotRunning();\n this.postControllerMiddlewares.push(...middlewares);\n\n return this;\n }\n\n public registerPreControllerMiddlewares(\n ...middlewares: RequestHandler[]\n ): this {\n this.assertServerIsNotRunning();\n this.preControllerMiddlewares.push(...middlewares);\n\n return this;\n }\n\n public async run(): Promise<void> {\n if (this.serverInstance) {\n throw new Error('HTTP server is already running.');\n }\n\n const controllers = [\n ...this.options.kernel.getRoutes(),\n ...this.controllers,\n ];\n const express = this.getExpress();\n const { useExpressServer } = this.getRoutingControllers();\n const app = express() as HttpApp;\n\n this.applyMiddlewares(app, this.middlewares);\n this.applyMiddlewares(app, this.preControllerMiddlewares);\n await this.runHooks(this.beforeControllersHooks, app);\n await this.runPhaseHooks('beforeControllers', app);\n this.configureControllerContainer();\n useExpressServer(app, {\n ...this.options.routingControllersOptions,\n controllers,\n routePrefix: this.options.routePrefix,\n });\n this.applyMiddlewares(app, this.postControllerMiddlewares);\n await this.runHooks(this.afterControllersHooks, app);\n await this.runPhaseHooks('afterControllers', app);\n await this.runHooks(this.swaggerHooks, app);\n await this.runHooks(this.staticHooks, app);\n await this.runPhaseHooks('beforeErrors', app);\n\n this.applyErrorHandlers(app);\n this.appInstance = app;\n\n return new Promise((resolve) => {\n this.serverInstance = app.listen(this.options.port ?? 3000, () => {\n resolve();\n });\n });\n }\n}\n","import type { NextFunction, Request, Response } from 'express';\n\nimport {\n type ExpressErrorMiddlewareInterface,\n HttpError,\n} from 'routing-controllers';\n\nimport type { ErrorExplanation } from './ErrorExplanation.js';\nimport type { ErrorResponseHandler } from './ErrorResponseHandler.js';\nimport type { FormattedValidationError } from './FormattedValidationError.js';\nimport type { HttpErrorHandlerOptions } from './HttpErrorHandlerOptions.js';\nimport type { HttpErrorLike } from './HttpErrorLike.js';\nimport type { PayloadTooLargeError } from './PayloadTooLargeError.js';\nimport type { ValidationError } from './ValidationError.js';\n\nimport { HttpRouteStatusEnum } from '../../../contracts/ui/index.js';\n\nexport class HttpErrorHandler implements ExpressErrorMiddlewareInterface {\n private readonly handlers: readonly ErrorResponseHandler[];\n\n private readonly exposeUnhandledErrorsIn: readonly string[];\n\n constructor(private readonly options: HttpErrorHandlerOptions = {}) {\n this.handlers = options.handlers ?? [];\n this.exposeUnhandledErrorsIn = options.exposeUnhandledErrorsIn ?? [\n 'local',\n 'test',\n ];\n }\n\n private formatValidationErrors(\n errors: readonly ValidationError[],\n ): FormattedValidationError[] {\n return errors.flatMap((error) => {\n if (error.children && error.children.length > 0) {\n return this.formatValidationErrors(error.children);\n }\n\n return [\n {\n details: error.constraints,\n property: error.property,\n value: error.value,\n },\n ];\n });\n }\n\n private getErrorMessage(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n }\n\n private getHttpStatus(error: HttpErrorLike): number | undefined {\n return error.httpCode ?? error.statusCode ?? error.status;\n }\n\n private isPayloadTooLargeError(error: PayloadTooLargeError): boolean {\n return (\n error.type === 'entity.too.large' ||\n this.getHttpStatus(error) === HttpRouteStatusEnum.PAYLOAD_TOO_LARGE\n );\n }\n\n private logUnhandledError(error: Error): void {\n this.options.logger?.error(`Unhandled error: ${error.message}`);\n this.options.logger?.debug(error.stack ?? 'No stack trace available');\n }\n\n private handleSyntaxError(error: Error, response: Response): boolean {\n if (!(error instanceof SyntaxError)) {\n return false;\n }\n\n response.status(HttpRouteStatusEnum.BAD_REQUEST).json({\n code: 'SyntaxError',\n message: 'Malformed JSON',\n });\n\n return true;\n }\n\n private handlePayloadTooLargeError(\n error: Error,\n response: Response,\n ): boolean {\n if (!this.isPayloadTooLargeError(error)) {\n return false;\n }\n\n response.status(HttpRouteStatusEnum.PAYLOAD_TOO_LARGE).json({\n code: 'PayloadTooLargeError',\n httpStatus: HttpRouteStatusEnum.PAYLOAD_TOO_LARGE,\n message: 'Request entity too large.',\n });\n\n return true;\n }\n\n private handleHttpError(error: Error, response: Response): boolean {\n const httpError = error as HttpErrorLike;\n const httpStatus = this.getHttpStatus(httpError);\n\n if (!httpStatus && !(error instanceof HttpError)) {\n return false;\n }\n\n response\n .status(httpStatus ?? HttpRouteStatusEnum.INTERNAL_SERVER_ERROR)\n .json({\n code: error.name,\n errors: this.formatValidationErrors(\n (error as ErrorExplanation).errors ?? [],\n ),\n httpStatus: httpStatus ?? HttpRouteStatusEnum.INTERNAL_SERVER_ERROR,\n message: error.message,\n });\n\n return true;\n }\n\n private handleUnhandledError(error: Error, response: Response): void {\n if (this.exposeUnhandledErrorsIn.includes(process.env.NODE_ENV ?? '')) {\n this.logUnhandledError(error);\n }\n\n response.status(HttpRouteStatusEnum.INTERNAL_SERVER_ERROR).json({\n code:\n error.constructor.name ||\n String(HttpRouteStatusEnum.INTERNAL_SERVER_ERROR),\n message: error.message || 'Unknown error',\n });\n }\n\n public error(\n error: Error,\n request: Request,\n response: Response,\n next: NextFunction,\n ): void {\n void request;\n\n const handlers: ErrorResponseHandler[] = [\n this.handleSyntaxError.bind(this),\n this.handlePayloadTooLargeError.bind(this),\n ...this.handlers,\n this.handleHttpError.bind(this),\n ];\n\n if (handlers.some((handler) => handler(error, response))) {\n return;\n }\n\n void next;\n\n this.handleUnhandledError(error, response);\n }\n\n public handle = (\n error: Error,\n request: Request,\n response: Response,\n next: NextFunction,\n ): void => {\n this.error(error, request, response, next);\n };\n}\n\nexport default HttpErrorHandler;\n","export const HttpRouteStatusEnum = {\n BAD_REQUEST: 400,\n CONFLICT: 409,\n CREATED: 201,\n DEPRECATED: 299,\n FORBIDDEN: 403,\n INTERNAL_SERVER_ERROR: 500,\n NO_CONTENT: 204,\n NOT_FOUND: 404,\n OK: 200,\n PAYLOAD_TOO_LARGE: 413,\n SERVICE_UNAVAILABLE: 503,\n TOO_MANY_REQUESTS: 429,\n UNAUTHORIZED: 401,\n UNPROCESSABLE_ENTITY: 422,\n} as const;\n\nexport default HttpRouteStatusEnum;\n","export class RoutePrefix {\n private readonly value: string;\n\n public static fromEnvironment(value: string | undefined): RoutePrefix {\n return new RoutePrefix(value);\n }\n\n constructor(value: string | undefined) {\n if (!value || value === '/') {\n this.value = '';\n\n return;\n }\n\n const normalizedPrefix = value\n .trim()\n .replace(/^\\/+/, '')\n .replace(/\\/+$/, '');\n\n this.value = normalizedPrefix ? `/${normalizedPrefix}` : '';\n }\n\n public includes(requestPath: string): boolean {\n return (\n this.value.length > 0 &&\n (requestPath === this.value || requestPath.startsWith(`${this.value}/`))\n );\n }\n\n public isEmpty(): boolean {\n return this.value.length === 0;\n }\n\n public toString(): string {\n return this.value;\n }\n}\n","import { Kernel } from '../../../Kernel.js';\n\nexport abstract class Route {\n public get<T>(service: unknown): T {\n return Kernel.di.getService<T>(service);\n }\n}\n\nexport default Route;\n"],"mappings":"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","names":["path","path","path"]}
|