@noego/ioc 0.2.1 → 0.2.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/framework/implementation/Container.cjs +46 -36
- package/dist/framework/implementation/Container.cjs.map +1 -1
- package/dist/framework/implementation/Container.js +46 -36
- package/dist/framework/implementation/Container.js.map +1 -1
- package/dist/framework/implementation/TraceLogger.cjs +84 -183
- package/dist/framework/implementation/TraceLogger.cjs.map +1 -1
- package/dist/framework/implementation/TraceLogger.js +85 -174
- package/dist/framework/implementation/TraceLogger.js.map +1 -1
- package/package.json +1 -5
|
@@ -336,56 +336,66 @@ class Container {
|
|
|
336
336
|
const storageType = this.getStorageType(funcLabel);
|
|
337
337
|
const labelStr = String(funcLabel);
|
|
338
338
|
if (storageType && this.hasInstance(funcLabel)) {
|
|
339
|
-
|
|
340
|
-
return instance;
|
|
339
|
+
return this.getInstance(funcLabel);
|
|
341
340
|
}
|
|
342
341
|
const ioc_func = functionConfig.function;
|
|
343
342
|
const options = functionConfig.options;
|
|
344
343
|
const dependenciesToResolve = options?.param || [];
|
|
345
344
|
const paramsCopy = [...params];
|
|
346
|
-
const
|
|
347
|
-
|
|
348
|
-
)
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
if (
|
|
352
|
-
|
|
353
|
-
if (storageType === "scoped") this._functionStorageScoped.delete(funcLabel);
|
|
345
|
+
const resolvedDependencies = [];
|
|
346
|
+
let hasAsyncDependency = false;
|
|
347
|
+
for (const dependencyIdentifier of dependenciesToResolve) {
|
|
348
|
+
const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain);
|
|
349
|
+
resolvedDependencies.push(resolved);
|
|
350
|
+
if (isPromise(resolved)) {
|
|
351
|
+
hasAsyncDependency = true;
|
|
354
352
|
}
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
353
|
+
}
|
|
354
|
+
const invoke = (deps) => {
|
|
355
|
+
try {
|
|
356
|
+
const result = ioc_func.apply(null, deps);
|
|
357
|
+
if (isPromise(result)) {
|
|
358
|
+
return result.then((resolved) => {
|
|
359
|
+
if (storageType && storageType !== "transient") {
|
|
360
|
+
this.setInstance(funcLabel, resolved, storageType);
|
|
361
|
+
}
|
|
362
|
+
return resolved;
|
|
363
|
+
}).catch((err) => {
|
|
365
364
|
console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);
|
|
366
365
|
if (storageType === "singleton") this._functionStorageSingleton.delete(funcLabel);
|
|
367
366
|
if (storageType === "scoped") this._functionStorageScoped.delete(funcLabel);
|
|
368
367
|
throw err;
|
|
369
|
-
}
|
|
370
|
-
}
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
console.error(`[IOC LoadFunc] Error executing transient function ${labelStr}: ${err.message}`, err.stack);
|
|
379
|
-
throw err;
|
|
380
|
-
}
|
|
381
|
-
})();
|
|
368
|
+
});
|
|
369
|
+
}
|
|
370
|
+
if (storageType && storageType !== "transient") {
|
|
371
|
+
this.setInstance(funcLabel, result, storageType);
|
|
372
|
+
}
|
|
373
|
+
return result;
|
|
374
|
+
} catch (err) {
|
|
375
|
+
console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);
|
|
376
|
+
throw err;
|
|
382
377
|
}
|
|
383
|
-
|
|
378
|
+
};
|
|
379
|
+
if (!hasAsyncDependency) {
|
|
380
|
+
const instance = invoke(resolvedDependencies);
|
|
381
|
+
if (isPromise(instance) && storageType && storageType !== "transient") {
|
|
382
|
+
this.setInstance(funcLabel, instance, storageType);
|
|
383
|
+
}
|
|
384
|
+
return instance;
|
|
385
|
+
}
|
|
386
|
+
const asyncInstance = Promise.all(resolvedDependencies).then((deps) => {
|
|
387
|
+
const instance = invoke(deps);
|
|
388
|
+
return instance;
|
|
389
|
+
}).catch((error) => {
|
|
390
|
+
console.error(`[IOC LoadFunc] Failed to resolve dependencies for function ${labelStr}:`, error);
|
|
391
|
+
if (storageType === "singleton") this._functionStorageSingleton.delete(funcLabel);
|
|
392
|
+
if (storageType === "scoped") this._functionStorageScoped.delete(funcLabel);
|
|
393
|
+
throw error;
|
|
384
394
|
});
|
|
385
395
|
if (storageType && storageType !== "transient") {
|
|
386
|
-
this.setInstance(funcLabel,
|
|
396
|
+
this.setInstance(funcLabel, asyncInstance, storageType);
|
|
387
397
|
}
|
|
388
|
-
return
|
|
398
|
+
return asyncInstance;
|
|
389
399
|
}
|
|
390
400
|
}
|
|
391
401
|
function isPromise(obj) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../framework/implementation/Container.ts"],"sourcesContent":["import 'reflect-metadata'; // Ensure polyfill is loaded conceptually\nimport type { ContainerOptions, IContainerClient, IContainerFunctionDefinition, IContainerSetup } from \"../interface/Container.cjs\";\nimport { LoadAs } from \"./LoadAs.cjs\";\nimport { Parameter } from \"./Parameter.cjs\";\nimport type { ParameterValue } from \"./Parameter.cjs\";\nimport { NotAClassDefinitionError, ParameterNotFoundError, DependencyNotFoundError, InstanceNotCreatedError, CircularDependencyError } from \"../errors/ContainerErrors.cjs\";\nimport {\n getScope,\n getComponentOptions, // Use helper\n getResolvedDependencies // Use helper\n} from './DecoratorSupport'; // Assume helpers exist or create them\nimport { wrapWithProxy, setTraceLogger, reserveProxyId } from \"./ProxyFactory.cjs\";\nimport * as TraceLoggerModule from \"./TraceLogger.cjs\";\nimport { TraceCleanup } from \"./TraceCleanup.cjs\";\n\n/**\n * A special injection token that resolves to the current scoped container.\n * Use this as a dependency in param arrays to have the container inject itself.\n * This allows provider classes to resolve additional dependencies on demand.\n */\nexport const SCOPED_CONTAINER = Symbol.for(\"ioc:scoped-container\");\n\nenum ContainerRouting {\n FUNCTIONAL = \"FUNCTIONAL\",\n CLASS = \"CLASS\"\n // No need for COMPONENT route, just check metadata if CLASS/FUNCTIONAL fails\n}\n\ntype StorageType = 'singleton' | 'scoped' | 'transient';\n\nexport class Container implements IContainerClient, IContainerSetup {\n // Routing and definition maps\n private _routing: Map<any, ContainerRouting> = new Map();\n private _functionDefinition: Map<any, IContainerFunctionDefinition> = new Map();\n private _classDefinition: Map<Function, Partial<ContainerOptions>> = new Map();\n\n // Storage maps\n private _functionStorageSingleton: Map<any, any> = new Map();\n private _functionStorageScoped: Map<any, any> = new Map();\n private _classStorageSingleton: Map<Function, any> = new Map();\n private _classStorageScoped: Map<Function, any> = new Map();\n\n // Tracing configuration\n private _enableTracing: boolean = false;\n private _traceRetentionMinutes: number = 5;\n\n // Registration methods\n registerClass<T>(classDefinition: new (...args: any[]) => T, options?: Partial<ContainerOptions>): void {\n // Basic validation\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n console.warn(`[IOC] Attempted to register non-class: ${String(classDefinition)}`);\n // Optional: throw error instead?\n // throw new NotAClassDefinitionError(`Attempted to register non-class: ${String(classDefinition)}`);\n return; // Don't proceed if not a class constructor\n }\n\n // Always clear previous definitions for this exact class constructor\n this.clearDefinitions(classDefinition);\n\n // Always set the routing type so 'isClassDefinition' works\n this._routing.set(classDefinition, ContainerRouting.CLASS);\n\n // Store manual options *only if they are actually provided and have content*\n if (options && Object.keys(options).length > 0) {\n this._classDefinition.set(classDefinition, options);\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with options:`, options);\n } else {\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with no specific options (will use decorators if present).`);\n // If no options are provided, we don't store anything in _classDefinition,\n // effectively clearing any previous manual config and letting decorators take over if present.\n }\n }\n\n registerFunction<T extends (...arg: any[]) => any>(label: any, func: T, options: Partial<ContainerOptions> = {} as any): void {\n this.clearDefinitions(label);\n this._routing.set(label, ContainerRouting.FUNCTIONAL);\n this._functionDefinition.set(label, { function: func, options });\n // console.log(`[IOC RegFunc] Registered function with label ${String(label)} and options:`, options);\n }\n\n // Instance resolution methods - Simplify to just call loadInstance\n instance<T, Sync extends boolean = false>(classDefinition: new (...args: any[]) => T, params: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Basic check upfront\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n throw new NotAClassDefinitionError(`Cannot resolve instance for non-class: ${String(classDefinition)}`);\n }\n return this.loadInstance(classDefinition, params);\n }\n\n get<T, Sync extends boolean = false>(label: any, param: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Just delegate to loadInstance, which handles routing and auto-registration\n return this.loadInstance(label, param);\n }\n\n extend(): IContainerClient & IContainerSetup {\n const childContainer = createContainer() as Container;\n\n // Copy routing and definition maps (share the registration knowledge)\n childContainer._routing = new Map(this._routing);\n childContainer._functionDefinition = new Map(this._functionDefinition);\n childContainer._classDefinition = new Map(this._classDefinition);\n\n // Share singleton storage (singletons are shared across all containers)\n childContainer._functionStorageSingleton = this._functionStorageSingleton;\n childContainer._classStorageSingleton = this._classStorageSingleton;\n\n // Do NOT share scoped storage (new container = new scope)\n // Child gets its own empty scoped storage\n\n // Share tracing configuration\n childContainer._enableTracing = this._enableTracing;\n childContainer._traceRetentionMinutes = this._traceRetentionMinutes;\n\n // console.log('[IOC Extend] Created child container.');\n return childContainer;\n }\n\n // Tracing API\n setTracingEnabled(enabled: boolean): void {\n this._enableTracing = enabled;\n if (enabled && !TraceCleanup.isCleanupRunning()) {\n // Set the trace logger for the ProxyFactory\n setTraceLogger(TraceLoggerModule as any);\n // Start automatic cleanup\n TraceCleanup.start(this._traceRetentionMinutes);\n }\n }\n\n isTracingEnabled(): boolean {\n return this._enableTracing;\n }\n\n setTraceRetentionMinutes(minutes: number): void {\n this._traceRetentionMinutes = Math.max(1, minutes);\n }\n\n getTraces(retentionMinutes?: number): any[] {\n const retention = retentionMinutes ?? this._traceRetentionMinutes;\n return TraceLoggerModule.getRecentTraces(retention);\n }\n\n getAllTraces(): any[] {\n return TraceLoggerModule.getAllTraces();\n }\n\n clearTraces(): void {\n TraceLoggerModule.clearAllTraces();\n }\n\n exportTraces(filepath: string): void {\n const data = TraceLoggerModule.exportTracesToJson();\n const fs = require('fs');\n fs.writeFileSync(filepath, JSON.stringify(data, null, 2));\n }\n\n getTraceStatistics(): any {\n return TraceLoggerModule.getTraceStatistics();\n }\n\n // Private helper methods\n private clearDefinitions(label: any): void {\n this._routing.delete(label);\n this._functionDefinition.delete(label);\n // Only delete from classDefinition if the label is actually a function constructor\n if (typeof label === 'function') {\n this._classDefinition.delete(label);\n }\n }\n\n // Checks if the label is *currently* registered as a class\n private isRegisteredAsClass(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.CLASS;\n }\n\n // Checks if the label is *currently* registered as a function\n private isRegisteredAsFunction(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.FUNCTIONAL;\n }\n\n\n private hasInstance(label: any): boolean {\n const storageType = this.getStorageType(label); // This checks decorators if needed\n\n if (!storageType) {\n // Transient instances are never stored\n return false;\n }\n\n // Determine if it's treated as a class (registered or decorated) *after* getting type\n const isClass = this.isClassType(label); // Use a helper that checks routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.has(label)\n : this._classStorageScoped.has(label);\n } else { // Must be a function if not a class\n return storageType === 'singleton'\n ? this._functionStorageSingleton.has(label)\n : this._functionStorageScoped.has(label);\n }\n }\n\n // Helper to determine if something should be treated as a class (registered or decorated)\n private isClassType(label: any): boolean {\n if (this.isRegisteredAsClass(label)) {\n return true;\n }\n // If not explicitly registered as a class, check if it's a function with @Component\n if (typeof label === 'function' && label.prototype && !this.isRegisteredAsFunction(label)) {\n return getComponentOptions(label) !== null;\n }\n return false;\n }\n\n private getInstance(label: any): any {\n const storageType = this.getStorageType(label); // Checks decorators if needed\n\n if (!storageType) {\n // This should ideally not be reached if called after hasInstance check\n console.error(`[IOC GetInstance] Attempted to get instance for non-stored type: ${String(label)}`);\n throw new InstanceNotCreatedError();\n }\n\n const isClass = this.isClassType(label); // Check routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.get(label)\n : this._classStorageScoped.get(label);\n } else { // Must be a function\n return storageType === 'singleton'\n ? this._functionStorageSingleton.get(label)\n : this._functionStorageScoped.get(label);\n }\n }\n\n private setInstance(label: any, instance: any, storageType?: StorageType): void { // Made storageType non-optional\n const isClass = this.isClassType(label); // Determine type based on routing OR decorator\n\n if (isClass) {\n if (storageType === 'singleton') {\n this._classStorageSingleton.set(label, instance);\n } else if (storageType == 'scoped'){ // storageType === 'scoped'\n this._classStorageScoped.set(label, instance);\n }\n } else { // Must be a function\n if (storageType === 'singleton') {\n this._functionStorageSingleton.set(label, instance);\n } else if(storageType === \"scoped\"){ // storageType === 'scoped'\n this._functionStorageScoped.set(label, instance);\n }\n }\n }\n\n private getStorageType(label: any): StorageType {\n let manualLoadAs: LoadAs | undefined;\n let decoratorScope: LoadAs | undefined;\n const isPotentialClass = typeof label === 'function' && label.prototype;\n\n // Get manual registration options if available\n if (this.isRegisteredAsClass(label)) { // Use helper\n manualLoadAs = this._classDefinition.get(label)?.loadAs;\n } else if (this.isRegisteredAsFunction(label)) { // Use helper\n manualLoadAs = this._functionDefinition.get(label)?.options?.loadAs;\n }\n\n // Get decorator scope only if it's potentially a class *and not explicitly registered as a function*\n if (isPotentialClass && !this.isRegisteredAsFunction(label)) {\n decoratorScope = getScope(label); // Uses getComponentOptions internally\n }\n\n // Determine final scope: Manual > Decorator > Default (Transient)\n const finalScope = manualLoadAs ?? decoratorScope ?? LoadAs.Transient;\n\n if (finalScope === LoadAs.Singleton) {\n return 'singleton';\n } else if (finalScope === LoadAs.Scoped) {\n return 'scoped';\n }else{\n return 'transient'; // Transient\n }\n }\n\n // Central resolution logic - sync-first, returns T or Promise<T>\n protected loadInstance(\n label: any,\n params: ParameterValue<any>[] = [],\n resolutionChain: string[] = [], // Track resolution path\n parentProxyId?: number // For proxy hierarchy tracking\n ): any {\n\n // --- Circular Dependency Check ---\n const currentLabelStr = (typeof label === 'function' && label.name) ? label.name : String(label);\n if (resolutionChain.includes(currentLabelStr)) {\n console.error(`[IOC LoadInstance] Circular dependency detected: ${[...resolutionChain, currentLabelStr].join(' -> ')}`);\n throw new CircularDependencyError([...resolutionChain, currentLabelStr]);\n }\n const nextResolutionChain = [...resolutionChain, currentLabelStr];\n // --- End Circular Dependency Check ---\n\n // --- Handle Parameters ---\n if (label instanceof Parameter) {\n try {\n // Pass a *copy* of params to avoid side effects in resolveParameterValue\n return this.resolveParameterValue(label, [...params]);\n } catch (e) {\n // console.error(`[IOC LoadInstance] Error resolving parameter ${param.toString()}:`, e);\n throw e;\n }\n }\n // --- End Handle Parameters ---\n\n // --- Handle Scoped Container Injection ---\n if (label === SCOPED_CONTAINER) {\n return this;\n }\n // --- End Handle Scoped Container Injection ---\n\n // --- Check Explicit Registrations ---\n if (this.isRegisteredAsClass(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered class: ${currentLabelStr}`);\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n if (this.isRegisteredAsFunction(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered function: ${currentLabelStr}`);\n return this.loadFunctionInstance(label, params, nextResolutionChain);\n }\n // --- End Check Explicit Registrations ---\n\n\n // --- Attempt Auto-Registration/Resolution for Decorated Classes ---\n if (typeof label === 'function' && label.prototype) {\n const componentOptions = getComponentOptions(label); // Check for @Component\n if (componentOptions !== null) {\n // console.log(`[IOC LoadInstance] Auto-resolving @Component class: ${currentLabelStr}`);\n // Set routing *now* so subsequent internal checks work correctly\n if (!this._routing.has(label)) { // Only set if not already set\n this._routing.set(label, ContainerRouting.CLASS);\n // console.log(`[IOC LoadInstance] Set routing for auto-resolved class: ${currentLabelStr}`);\n }\n // Proceed to load it as a class\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n }\n // --- End Auto-Registration ---\n\n\n // --- Dependency Not Found ---\n console.error(`[IOC LoadInstance] Dependency not found and cannot be resolved: ${currentLabelStr}`);\n throw new DependencyNotFoundError(currentLabelStr);\n }\n\n\n private resolveParameterValue(param: Parameter, params: ParameterValue<any>[]): any { // No mutation\n // Find the *last* provided value for the parameter\n const valueContainer = [...params].reverse().find((p) => p.belongsTo(param));\n if (!valueContainer) {\n // console.error(`[IOC ResolveParam] Parameter not found: ${param.toString()}`);\n throw new ParameterNotFoundError(param.toString());\n }\n // console.log(`[IOC ResolveParam] Resolved parameter ${param.toString()}`);\n return valueContainer.value;\n }\n\n private loadClassInstance(\n classDefinition: any, // Should be a class constructor here\n params: ParameterValue<any>[],\n resolutionChain: string[],\n parentProxyId?: number\n ): any {\n const storageType = this.getStorageType(classDefinition);\n const className = classDefinition.name || '[Anonymous Class]';\n\n // Check storage first (may be sync value or Promise)\n if (storageType && this.hasInstance(classDefinition)) {\n const instance = this.getInstance(classDefinition);\n // console.log(`[IOC LoadClass] Found existing ${storageType} instance for ${className}. IsPromise: ${isPromise(instance)}`);\n return instance;\n }\n // console.log(`[IOC LoadClass] Creating new ${storageType || 'transient'} instance for ${className}`);\n\n // --- Determine Dependencies ---\n const manualOptions = this._classDefinition.get(classDefinition) as ContainerOptions | undefined;\n let dependenciesToResolve: any[];\n\n if (manualOptions?.param && Array.isArray(manualOptions.param)) {\n dependenciesToResolve = manualOptions.param;\n // console.log(`[IOC LoadClass] Using manual dependencies for ${className}`);\n } else {\n // Use decorator-derived dependencies\n dependenciesToResolve = getResolvedDependencies(classDefinition);\n // console.log(`[IOC LoadClass] Using decorator/reflected dependencies for ${className}:`, dependenciesToResolve.map(d => typeof d === 'function' ? d.name : String(d)));\n }\n // --- End Determine Dependencies ---\n\n // Reserve a proxy ID if tracing is enabled\n let futureProxyId: number | undefined;\n if (this._enableTracing) {\n futureProxyId = reserveProxyId();\n }\n\n // --- Resolve Dependencies (sync-first) ---\n const paramsCopy = [...params];\n const resolvedDependencies: any[] = [];\n let hasAsyncDependency = false;\n\n // Resolve each dependency and check if any return Promises\n for (const dependencyIdentifier of dependenciesToResolve) {\n const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain, futureProxyId);\n resolvedDependencies.push(resolved);\n if (isPromise(resolved)) {\n hasAsyncDependency = true;\n }\n }\n\n // Helper to instantiate the class\n const instantiate = (deps: any[]): any => {\n try {\n const instance = new classDefinition(...deps);\n\n // Wrap with proxy if tracing is enabled\n if (this._enableTracing && futureProxyId !== undefined) {\n return wrapWithProxy(instance, className, parentProxyId, futureProxyId);\n }\n return instance;\n } catch (err: any) {\n console.error(`[IOC LoadClass] Error during instantiation of ${className}: ${err.message}`, err.stack);\n throw err;\n }\n };\n\n // --- Sync Path: All dependencies resolved synchronously ---\n if (!hasAsyncDependency) {\n const instance = instantiate(resolvedDependencies);\n\n // Store if singleton/scoped\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n }\n\n // --- Async Path: At least one dependency is a Promise ---\n const asyncInstance = Promise.all(resolvedDependencies)\n .then((deps) => {\n const instance = instantiate(deps);\n\n // Store if singleton/scoped (overwrite the promise with the instance)\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n })\n .catch((error) => {\n console.error(`[IOC LoadClass] Failed to resolve one or more dependencies for ${className}:`, error);\n // Clean up stored promise on failure\n if (storageType && this.isRegisteredAsClass(classDefinition)) {\n if (storageType === 'singleton') this._classStorageSingleton.delete(classDefinition);\n if (storageType === 'scoped') this._classStorageScoped.delete(classDefinition);\n }\n throw error;\n });\n\n // Store the promise for singleton/scoped to handle concurrent requests\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, asyncInstance, storageType);\n }\n\n return asyncInstance;\n }\n\n private loadFunctionInstance(\n funcLabel: any,\n params: ParameterValue<any>[],\n resolutionChain: string[]\n ): Promise<any> { // Always return Promise<any> since this is an async function\n const functionConfig = this._functionDefinition.get(funcLabel)!; // Assumed to exist by caller\n const storageType = this.getStorageType(funcLabel); // Only uses manual options for functions\n const labelStr = String(funcLabel);\n\n // Check storage first\n if (storageType && this.hasInstance(funcLabel)) {\n const instance = this.getInstance(funcLabel);\n // console.log(`[IOC LoadFunc] Found existing ${storageType} instance for ${labelStr}. IsPromise: ${isPromise(instance)}`);\n return instance;\n }\n // console.log(`[IOC LoadFunc] Creating new ${storageType || 'transient'} instance for ${labelStr}`);\n\n const ioc_func = functionConfig.function;\n const options = functionConfig.options;\n const dependenciesToResolve: any[] = options?.param || [];\n\n // --- Resolve Dependencies ---\n const paramsCopy = [...params]; // Create a copy\n const resolutionPromises = dependenciesToResolve.map(dependencyIdentifier =>\n this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain)\n );\n\n let finalInstance = Promise.all(resolutionPromises).catch((error)=>{\n console.error(`[IOC LoadFunc] Failed to resolve dependencies for function ${labelStr}:`, error);\n // Clean up potential partial storage\n if (storageType && this.isRegisteredAsFunction(funcLabel)) {\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n }\n throw error;\n }).then(async(resolvedArgs)=>{\n let instancePromise: Promise<any> | undefined;\n if (storageType && !this.hasInstance(funcLabel)) {\n instancePromise = (async () => {\n try {\n // console.log(`[IOC LoadFunc] Invoking ${labelStr} with ${resolvedArgs.length} args.`);\n const result = await ioc_func.apply(null, resolvedArgs); // Await in case function is async\n // Overwrite stored promise with actual result\n this.setInstance(funcLabel, result, storageType);\n // console.log(`[IOC LoadFunc] Stored actual ${storageType} instance for ${labelStr}`);\n return result;\n } catch (err: any) {\n console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);\n // Clean up stored promise on failure\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n throw err;\n }\n })();\n // console.log(`[IOC LoadFunc] Storing promise for concurrent requests (${storageType}) for ${labelStr}`);\n this.setInstance(funcLabel, instancePromise, storageType);\n } else {\n // Transient or already resolved from storage check\n instancePromise = (async () => {\n try {\n // console.log(`[IOC LoadFunc] Invoking transient ${labelStr} with ${resolvedArgs.length} args.`);\n const result = await ioc_func.apply(null, resolvedArgs); // Await in case function is async\n // No storing for transient\n return result;\n } catch (err: any) {\n console.error(`[IOC LoadFunc] Error executing transient function ${labelStr}: ${err.message}`, err.stack);\n throw err;\n }\n })();\n }\n // --- End Invoke Function ---\n\n return await instancePromise; // Return the final (awaited) result\n });\n\n if(storageType && storageType !== 'transient'){\n this.setInstance(funcLabel, finalInstance, storageType); // Store the promise\n }\n\n return finalInstance;\n }\n}\n\n// Helper functions\nexport function isPromise(obj: any): obj is Promise<any> {\n // Simplified check - more robust check might be needed depending on environment\n return !!obj && typeof obj.then === 'function';\n}\n\nexport function createContainer(): IContainerClient & IContainerSetup {\n return new Container();\n}\n"],"mappings":"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","names":["ContainerRouting"]}
|
|
1
|
+
{"version":3,"sources":["../../../framework/implementation/Container.ts"],"sourcesContent":["import 'reflect-metadata'; // Ensure polyfill is loaded conceptually\nimport type { ContainerOptions, IContainerClient, IContainerFunctionDefinition, IContainerSetup } from \"../interface/Container.cjs\";\nimport { LoadAs } from \"./LoadAs.cjs\";\nimport { Parameter } from \"./Parameter.cjs\";\nimport type { ParameterValue } from \"./Parameter.cjs\";\nimport { NotAClassDefinitionError, ParameterNotFoundError, DependencyNotFoundError, InstanceNotCreatedError, CircularDependencyError } from \"../errors/ContainerErrors.cjs\";\nimport {\n getScope,\n getComponentOptions, // Use helper\n getResolvedDependencies // Use helper\n} from './DecoratorSupport'; // Assume helpers exist or create them\nimport { wrapWithProxy, setTraceLogger, reserveProxyId } from \"./ProxyFactory.cjs\";\nimport * as TraceLoggerModule from \"./TraceLogger.cjs\";\nimport { TraceCleanup } from \"./TraceCleanup.cjs\";\n\n/**\n * A special injection token that resolves to the current scoped container.\n * Use this as a dependency in param arrays to have the container inject itself.\n * This allows provider classes to resolve additional dependencies on demand.\n */\nexport const SCOPED_CONTAINER = Symbol.for(\"ioc:scoped-container\");\n\nenum ContainerRouting {\n FUNCTIONAL = \"FUNCTIONAL\",\n CLASS = \"CLASS\"\n // No need for COMPONENT route, just check metadata if CLASS/FUNCTIONAL fails\n}\n\ntype StorageType = 'singleton' | 'scoped' | 'transient';\n\nexport class Container implements IContainerClient, IContainerSetup {\n // Routing and definition maps\n private _routing: Map<any, ContainerRouting> = new Map();\n private _functionDefinition: Map<any, IContainerFunctionDefinition> = new Map();\n private _classDefinition: Map<Function, Partial<ContainerOptions>> = new Map();\n\n // Storage maps\n private _functionStorageSingleton: Map<any, any> = new Map();\n private _functionStorageScoped: Map<any, any> = new Map();\n private _classStorageSingleton: Map<Function, any> = new Map();\n private _classStorageScoped: Map<Function, any> = new Map();\n\n // Tracing configuration\n private _enableTracing: boolean = false;\n private _traceRetentionMinutes: number = 5;\n\n // Registration methods\n registerClass<T>(classDefinition: new (...args: any[]) => T, options?: Partial<ContainerOptions>): void {\n // Basic validation\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n console.warn(`[IOC] Attempted to register non-class: ${String(classDefinition)}`);\n // Optional: throw error instead?\n // throw new NotAClassDefinitionError(`Attempted to register non-class: ${String(classDefinition)}`);\n return; // Don't proceed if not a class constructor\n }\n\n // Always clear previous definitions for this exact class constructor\n this.clearDefinitions(classDefinition);\n\n // Always set the routing type so 'isClassDefinition' works\n this._routing.set(classDefinition, ContainerRouting.CLASS);\n\n // Store manual options *only if they are actually provided and have content*\n if (options && Object.keys(options).length > 0) {\n this._classDefinition.set(classDefinition, options);\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with options:`, options);\n } else {\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with no specific options (will use decorators if present).`);\n // If no options are provided, we don't store anything in _classDefinition,\n // effectively clearing any previous manual config and letting decorators take over if present.\n }\n }\n\n registerFunction<T extends (...arg: any[]) => any>(label: any, func: T, options: Partial<ContainerOptions> = {} as any): void {\n this.clearDefinitions(label);\n this._routing.set(label, ContainerRouting.FUNCTIONAL);\n this._functionDefinition.set(label, { function: func, options });\n // console.log(`[IOC RegFunc] Registered function with label ${String(label)} and options:`, options);\n }\n\n // Instance resolution methods - Simplify to just call loadInstance\n instance<T, Sync extends boolean = false>(classDefinition: new (...args: any[]) => T, params: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Basic check upfront\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n throw new NotAClassDefinitionError(`Cannot resolve instance for non-class: ${String(classDefinition)}`);\n }\n return this.loadInstance(classDefinition, params);\n }\n\n get<T, Sync extends boolean = false>(label: any, param: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Just delegate to loadInstance, which handles routing and auto-registration\n return this.loadInstance(label, param);\n }\n\n extend(): IContainerClient & IContainerSetup {\n const childContainer = createContainer() as Container;\n\n // Copy routing and definition maps (share the registration knowledge)\n childContainer._routing = new Map(this._routing);\n childContainer._functionDefinition = new Map(this._functionDefinition);\n childContainer._classDefinition = new Map(this._classDefinition);\n\n // Share singleton storage (singletons are shared across all containers)\n childContainer._functionStorageSingleton = this._functionStorageSingleton;\n childContainer._classStorageSingleton = this._classStorageSingleton;\n\n // Do NOT share scoped storage (new container = new scope)\n // Child gets its own empty scoped storage\n\n // Share tracing configuration\n childContainer._enableTracing = this._enableTracing;\n childContainer._traceRetentionMinutes = this._traceRetentionMinutes;\n\n // console.log('[IOC Extend] Created child container.');\n return childContainer;\n }\n\n // Tracing API\n setTracingEnabled(enabled: boolean): void {\n this._enableTracing = enabled;\n if (enabled && !TraceCleanup.isCleanupRunning()) {\n // Set the trace logger for the ProxyFactory\n setTraceLogger(TraceLoggerModule as any);\n // Start automatic cleanup\n TraceCleanup.start(this._traceRetentionMinutes);\n }\n }\n\n isTracingEnabled(): boolean {\n return this._enableTracing;\n }\n\n setTraceRetentionMinutes(minutes: number): void {\n this._traceRetentionMinutes = Math.max(1, minutes);\n }\n\n getTraces(retentionMinutes?: number): any[] {\n const retention = retentionMinutes ?? this._traceRetentionMinutes;\n return TraceLoggerModule.getRecentTraces(retention);\n }\n\n getAllTraces(): any[] {\n return TraceLoggerModule.getAllTraces();\n }\n\n clearTraces(): void {\n TraceLoggerModule.clearAllTraces();\n }\n\n exportTraces(filepath: string): void {\n const data = TraceLoggerModule.exportTracesToJson();\n const fs = require('fs');\n fs.writeFileSync(filepath, JSON.stringify(data, null, 2));\n }\n\n getTraceStatistics(): any {\n return TraceLoggerModule.getTraceStatistics();\n }\n\n // Private helper methods\n private clearDefinitions(label: any): void {\n this._routing.delete(label);\n this._functionDefinition.delete(label);\n // Only delete from classDefinition if the label is actually a function constructor\n if (typeof label === 'function') {\n this._classDefinition.delete(label);\n }\n }\n\n // Checks if the label is *currently* registered as a class\n private isRegisteredAsClass(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.CLASS;\n }\n\n // Checks if the label is *currently* registered as a function\n private isRegisteredAsFunction(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.FUNCTIONAL;\n }\n\n\n private hasInstance(label: any): boolean {\n const storageType = this.getStorageType(label); // This checks decorators if needed\n\n if (!storageType) {\n // Transient instances are never stored\n return false;\n }\n\n // Determine if it's treated as a class (registered or decorated) *after* getting type\n const isClass = this.isClassType(label); // Use a helper that checks routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.has(label)\n : this._classStorageScoped.has(label);\n } else { // Must be a function if not a class\n return storageType === 'singleton'\n ? this._functionStorageSingleton.has(label)\n : this._functionStorageScoped.has(label);\n }\n }\n\n // Helper to determine if something should be treated as a class (registered or decorated)\n private isClassType(label: any): boolean {\n if (this.isRegisteredAsClass(label)) {\n return true;\n }\n // If not explicitly registered as a class, check if it's a function with @Component\n if (typeof label === 'function' && label.prototype && !this.isRegisteredAsFunction(label)) {\n return getComponentOptions(label) !== null;\n }\n return false;\n }\n\n private getInstance(label: any): any {\n const storageType = this.getStorageType(label); // Checks decorators if needed\n\n if (!storageType) {\n // This should ideally not be reached if called after hasInstance check\n console.error(`[IOC GetInstance] Attempted to get instance for non-stored type: ${String(label)}`);\n throw new InstanceNotCreatedError();\n }\n\n const isClass = this.isClassType(label); // Check routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.get(label)\n : this._classStorageScoped.get(label);\n } else { // Must be a function\n return storageType === 'singleton'\n ? this._functionStorageSingleton.get(label)\n : this._functionStorageScoped.get(label);\n }\n }\n\n private setInstance(label: any, instance: any, storageType?: StorageType): void { // Made storageType non-optional\n const isClass = this.isClassType(label); // Determine type based on routing OR decorator\n\n if (isClass) {\n if (storageType === 'singleton') {\n this._classStorageSingleton.set(label, instance);\n } else if (storageType == 'scoped'){ // storageType === 'scoped'\n this._classStorageScoped.set(label, instance);\n }\n } else { // Must be a function\n if (storageType === 'singleton') {\n this._functionStorageSingleton.set(label, instance);\n } else if(storageType === \"scoped\"){ // storageType === 'scoped'\n this._functionStorageScoped.set(label, instance);\n }\n }\n }\n\n private getStorageType(label: any): StorageType {\n let manualLoadAs: LoadAs | undefined;\n let decoratorScope: LoadAs | undefined;\n const isPotentialClass = typeof label === 'function' && label.prototype;\n\n // Get manual registration options if available\n if (this.isRegisteredAsClass(label)) { // Use helper\n manualLoadAs = this._classDefinition.get(label)?.loadAs;\n } else if (this.isRegisteredAsFunction(label)) { // Use helper\n manualLoadAs = this._functionDefinition.get(label)?.options?.loadAs;\n }\n\n // Get decorator scope only if it's potentially a class *and not explicitly registered as a function*\n if (isPotentialClass && !this.isRegisteredAsFunction(label)) {\n decoratorScope = getScope(label); // Uses getComponentOptions internally\n }\n\n // Determine final scope: Manual > Decorator > Default (Transient)\n const finalScope = manualLoadAs ?? decoratorScope ?? LoadAs.Transient;\n\n if (finalScope === LoadAs.Singleton) {\n return 'singleton';\n } else if (finalScope === LoadAs.Scoped) {\n return 'scoped';\n }else{\n return 'transient'; // Transient\n }\n }\n\n // Central resolution logic - sync-first, returns T or Promise<T>\n protected loadInstance(\n label: any,\n params: ParameterValue<any>[] = [],\n resolutionChain: string[] = [], // Track resolution path\n parentProxyId?: number // For proxy hierarchy tracking\n ): any {\n\n // --- Circular Dependency Check ---\n const currentLabelStr = (typeof label === 'function' && label.name) ? label.name : String(label);\n if (resolutionChain.includes(currentLabelStr)) {\n console.error(`[IOC LoadInstance] Circular dependency detected: ${[...resolutionChain, currentLabelStr].join(' -> ')}`);\n throw new CircularDependencyError([...resolutionChain, currentLabelStr]);\n }\n const nextResolutionChain = [...resolutionChain, currentLabelStr];\n // --- End Circular Dependency Check ---\n\n // --- Handle Parameters ---\n if (label instanceof Parameter) {\n try {\n // Pass a *copy* of params to avoid side effects in resolveParameterValue\n return this.resolveParameterValue(label, [...params]);\n } catch (e) {\n // console.error(`[IOC LoadInstance] Error resolving parameter ${param.toString()}:`, e);\n throw e;\n }\n }\n // --- End Handle Parameters ---\n\n // --- Handle Scoped Container Injection ---\n if (label === SCOPED_CONTAINER) {\n return this;\n }\n // --- End Handle Scoped Container Injection ---\n\n // --- Check Explicit Registrations ---\n if (this.isRegisteredAsClass(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered class: ${currentLabelStr}`);\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n if (this.isRegisteredAsFunction(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered function: ${currentLabelStr}`);\n return this.loadFunctionInstance(label, params, nextResolutionChain);\n }\n // --- End Check Explicit Registrations ---\n\n\n // --- Attempt Auto-Registration/Resolution for Decorated Classes ---\n if (typeof label === 'function' && label.prototype) {\n const componentOptions = getComponentOptions(label); // Check for @Component\n if (componentOptions !== null) {\n // console.log(`[IOC LoadInstance] Auto-resolving @Component class: ${currentLabelStr}`);\n // Set routing *now* so subsequent internal checks work correctly\n if (!this._routing.has(label)) { // Only set if not already set\n this._routing.set(label, ContainerRouting.CLASS);\n // console.log(`[IOC LoadInstance] Set routing for auto-resolved class: ${currentLabelStr}`);\n }\n // Proceed to load it as a class\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n }\n // --- End Auto-Registration ---\n\n\n // --- Dependency Not Found ---\n console.error(`[IOC LoadInstance] Dependency not found and cannot be resolved: ${currentLabelStr}`);\n throw new DependencyNotFoundError(currentLabelStr);\n }\n\n\n private resolveParameterValue(param: Parameter, params: ParameterValue<any>[]): any { // No mutation\n // Find the *last* provided value for the parameter\n const valueContainer = [...params].reverse().find((p) => p.belongsTo(param));\n if (!valueContainer) {\n // console.error(`[IOC ResolveParam] Parameter not found: ${param.toString()}`);\n throw new ParameterNotFoundError(param.toString());\n }\n // console.log(`[IOC ResolveParam] Resolved parameter ${param.toString()}`);\n return valueContainer.value;\n }\n\n private loadClassInstance(\n classDefinition: any, // Should be a class constructor here\n params: ParameterValue<any>[],\n resolutionChain: string[],\n parentProxyId?: number\n ): any {\n const storageType = this.getStorageType(classDefinition);\n const className = classDefinition.name || '[Anonymous Class]';\n\n // Check storage first (may be sync value or Promise)\n if (storageType && this.hasInstance(classDefinition)) {\n const instance = this.getInstance(classDefinition);\n // console.log(`[IOC LoadClass] Found existing ${storageType} instance for ${className}. IsPromise: ${isPromise(instance)}`);\n return instance;\n }\n // console.log(`[IOC LoadClass] Creating new ${storageType || 'transient'} instance for ${className}`);\n\n // --- Determine Dependencies ---\n const manualOptions = this._classDefinition.get(classDefinition) as ContainerOptions | undefined;\n let dependenciesToResolve: any[];\n\n if (manualOptions?.param && Array.isArray(manualOptions.param)) {\n dependenciesToResolve = manualOptions.param;\n // console.log(`[IOC LoadClass] Using manual dependencies for ${className}`);\n } else {\n // Use decorator-derived dependencies\n dependenciesToResolve = getResolvedDependencies(classDefinition);\n // console.log(`[IOC LoadClass] Using decorator/reflected dependencies for ${className}:`, dependenciesToResolve.map(d => typeof d === 'function' ? d.name : String(d)));\n }\n // --- End Determine Dependencies ---\n\n // Reserve a proxy ID if tracing is enabled\n let futureProxyId: number | undefined;\n if (this._enableTracing) {\n futureProxyId = reserveProxyId();\n }\n\n // --- Resolve Dependencies (sync-first) ---\n const paramsCopy = [...params];\n const resolvedDependencies: any[] = [];\n let hasAsyncDependency = false;\n\n // Resolve each dependency and check if any return Promises\n for (const dependencyIdentifier of dependenciesToResolve) {\n const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain, futureProxyId);\n resolvedDependencies.push(resolved);\n if (isPromise(resolved)) {\n hasAsyncDependency = true;\n }\n }\n\n // Helper to instantiate the class\n const instantiate = (deps: any[]): any => {\n try {\n const instance = new classDefinition(...deps);\n\n // Wrap with proxy if tracing is enabled\n if (this._enableTracing && futureProxyId !== undefined) {\n return wrapWithProxy(instance, className, parentProxyId, futureProxyId);\n }\n return instance;\n } catch (err: any) {\n console.error(`[IOC LoadClass] Error during instantiation of ${className}: ${err.message}`, err.stack);\n throw err;\n }\n };\n\n // --- Sync Path: All dependencies resolved synchronously ---\n if (!hasAsyncDependency) {\n const instance = instantiate(resolvedDependencies);\n\n // Store if singleton/scoped\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n }\n\n // --- Async Path: At least one dependency is a Promise ---\n const asyncInstance = Promise.all(resolvedDependencies)\n .then((deps) => {\n const instance = instantiate(deps);\n\n // Store if singleton/scoped (overwrite the promise with the instance)\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n })\n .catch((error) => {\n console.error(`[IOC LoadClass] Failed to resolve one or more dependencies for ${className}:`, error);\n // Clean up stored promise on failure\n if (storageType && this.isRegisteredAsClass(classDefinition)) {\n if (storageType === 'singleton') this._classStorageSingleton.delete(classDefinition);\n if (storageType === 'scoped') this._classStorageScoped.delete(classDefinition);\n }\n throw error;\n });\n\n // Store the promise for singleton/scoped to handle concurrent requests\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, asyncInstance, storageType);\n }\n\n return asyncInstance;\n }\n\n private loadFunctionInstance(\n funcLabel: any,\n params: ParameterValue<any>[],\n resolutionChain: string[]\n ): any {\n const functionConfig = this._functionDefinition.get(funcLabel)!;\n const storageType = this.getStorageType(funcLabel);\n const labelStr = String(funcLabel);\n\n // Check storage first\n if (storageType && this.hasInstance(funcLabel)) {\n return this.getInstance(funcLabel);\n }\n\n const ioc_func = functionConfig.function;\n const options = functionConfig.options;\n const dependenciesToResolve: any[] = options?.param || [];\n\n // --- Resolve Dependencies ---\n const paramsCopy = [...params];\n const resolvedDependencies: any[] = [];\n let hasAsyncDependency = false;\n\n for (const dependencyIdentifier of dependenciesToResolve) {\n const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain);\n resolvedDependencies.push(resolved);\n if (isPromise(resolved)) {\n hasAsyncDependency = true;\n }\n }\n\n // Helper to invoke the factory and store the result\n const invoke = (deps: any[]): any => {\n try {\n const result = ioc_func.apply(null, deps);\n\n // If factory returns a promise, handle async\n if (isPromise(result)) {\n return (result as Promise<any>).then((resolved) => {\n if (storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, resolved, storageType);\n }\n return resolved;\n }).catch((err: any) => {\n console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n throw err;\n });\n }\n\n // Sync result\n if (storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, result, storageType);\n }\n return result;\n } catch (err: any) {\n console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);\n throw err;\n }\n };\n\n // --- Sync Path: All dependencies resolved synchronously ---\n if (!hasAsyncDependency) {\n const instance = invoke(resolvedDependencies);\n if (isPromise(instance) && storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, instance, storageType);\n }\n return instance;\n }\n\n // --- Async Path: At least one dependency is a Promise ---\n const asyncInstance = Promise.all(resolvedDependencies)\n .then((deps) => {\n const instance = invoke(deps);\n return instance;\n })\n .catch((error) => {\n console.error(`[IOC LoadFunc] Failed to resolve dependencies for function ${labelStr}:`, error);\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n throw error;\n });\n\n if (storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, asyncInstance, storageType);\n }\n\n return asyncInstance;\n }\n}\n\n// Helper functions\nexport function isPromise(obj: any): obj is Promise<any> {\n // Simplified check - more robust check might be needed depending on environment\n return !!obj && typeof obj.then === 'function';\n}\n\nexport function createContainer(): IContainerClient & IContainerSetup {\n return new Container();\n}\n"],"mappings":"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","names":["ContainerRouting"]}
|
|
@@ -304,56 +304,66 @@ class Container {
|
|
|
304
304
|
const storageType = this.getStorageType(funcLabel);
|
|
305
305
|
const labelStr = String(funcLabel);
|
|
306
306
|
if (storageType && this.hasInstance(funcLabel)) {
|
|
307
|
-
|
|
308
|
-
return instance;
|
|
307
|
+
return this.getInstance(funcLabel);
|
|
309
308
|
}
|
|
310
309
|
const ioc_func = functionConfig.function;
|
|
311
310
|
const options = functionConfig.options;
|
|
312
311
|
const dependenciesToResolve = options?.param || [];
|
|
313
312
|
const paramsCopy = [...params];
|
|
314
|
-
const
|
|
315
|
-
|
|
316
|
-
)
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
if (
|
|
320
|
-
|
|
321
|
-
if (storageType === "scoped") this._functionStorageScoped.delete(funcLabel);
|
|
313
|
+
const resolvedDependencies = [];
|
|
314
|
+
let hasAsyncDependency = false;
|
|
315
|
+
for (const dependencyIdentifier of dependenciesToResolve) {
|
|
316
|
+
const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain);
|
|
317
|
+
resolvedDependencies.push(resolved);
|
|
318
|
+
if (isPromise(resolved)) {
|
|
319
|
+
hasAsyncDependency = true;
|
|
322
320
|
}
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
321
|
+
}
|
|
322
|
+
const invoke = (deps) => {
|
|
323
|
+
try {
|
|
324
|
+
const result = ioc_func.apply(null, deps);
|
|
325
|
+
if (isPromise(result)) {
|
|
326
|
+
return result.then((resolved) => {
|
|
327
|
+
if (storageType && storageType !== "transient") {
|
|
328
|
+
this.setInstance(funcLabel, resolved, storageType);
|
|
329
|
+
}
|
|
330
|
+
return resolved;
|
|
331
|
+
}).catch((err) => {
|
|
333
332
|
console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);
|
|
334
333
|
if (storageType === "singleton") this._functionStorageSingleton.delete(funcLabel);
|
|
335
334
|
if (storageType === "scoped") this._functionStorageScoped.delete(funcLabel);
|
|
336
335
|
throw err;
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
console.error(`[IOC LoadFunc] Error executing transient function ${labelStr}: ${err.message}`, err.stack);
|
|
347
|
-
throw err;
|
|
348
|
-
}
|
|
349
|
-
})();
|
|
336
|
+
});
|
|
337
|
+
}
|
|
338
|
+
if (storageType && storageType !== "transient") {
|
|
339
|
+
this.setInstance(funcLabel, result, storageType);
|
|
340
|
+
}
|
|
341
|
+
return result;
|
|
342
|
+
} catch (err) {
|
|
343
|
+
console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);
|
|
344
|
+
throw err;
|
|
350
345
|
}
|
|
351
|
-
|
|
346
|
+
};
|
|
347
|
+
if (!hasAsyncDependency) {
|
|
348
|
+
const instance = invoke(resolvedDependencies);
|
|
349
|
+
if (isPromise(instance) && storageType && storageType !== "transient") {
|
|
350
|
+
this.setInstance(funcLabel, instance, storageType);
|
|
351
|
+
}
|
|
352
|
+
return instance;
|
|
353
|
+
}
|
|
354
|
+
const asyncInstance = Promise.all(resolvedDependencies).then((deps) => {
|
|
355
|
+
const instance = invoke(deps);
|
|
356
|
+
return instance;
|
|
357
|
+
}).catch((error) => {
|
|
358
|
+
console.error(`[IOC LoadFunc] Failed to resolve dependencies for function ${labelStr}:`, error);
|
|
359
|
+
if (storageType === "singleton") this._functionStorageSingleton.delete(funcLabel);
|
|
360
|
+
if (storageType === "scoped") this._functionStorageScoped.delete(funcLabel);
|
|
361
|
+
throw error;
|
|
352
362
|
});
|
|
353
363
|
if (storageType && storageType !== "transient") {
|
|
354
|
-
this.setInstance(funcLabel,
|
|
364
|
+
this.setInstance(funcLabel, asyncInstance, storageType);
|
|
355
365
|
}
|
|
356
|
-
return
|
|
366
|
+
return asyncInstance;
|
|
357
367
|
}
|
|
358
368
|
}
|
|
359
369
|
function isPromise(obj) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../framework/implementation/Container.ts"],"sourcesContent":["import 'reflect-metadata'; // Ensure polyfill is loaded conceptually\nimport type { ContainerOptions, IContainerClient, IContainerFunctionDefinition, IContainerSetup } from \"../interface/Container.js\";\nimport { LoadAs } from \"./LoadAs.js\";\nimport { Parameter } from \"./Parameter.js\";\nimport type { ParameterValue } from \"./Parameter.js\";\nimport { NotAClassDefinitionError, ParameterNotFoundError, DependencyNotFoundError, InstanceNotCreatedError, CircularDependencyError } from \"../errors/ContainerErrors.js\";\nimport {\n getScope,\n getComponentOptions, // Use helper\n getResolvedDependencies // Use helper\n} from './DecoratorSupport'; // Assume helpers exist or create them\nimport { wrapWithProxy, setTraceLogger, reserveProxyId } from \"./ProxyFactory.js\";\nimport * as TraceLoggerModule from \"./TraceLogger.js\";\nimport { TraceCleanup } from \"./TraceCleanup.js\";\n\n/**\n * A special injection token that resolves to the current scoped container.\n * Use this as a dependency in param arrays to have the container inject itself.\n * This allows provider classes to resolve additional dependencies on demand.\n */\nexport const SCOPED_CONTAINER = Symbol.for(\"ioc:scoped-container\");\n\nenum ContainerRouting {\n FUNCTIONAL = \"FUNCTIONAL\",\n CLASS = \"CLASS\"\n // No need for COMPONENT route, just check metadata if CLASS/FUNCTIONAL fails\n}\n\ntype StorageType = 'singleton' | 'scoped' | 'transient';\n\nexport class Container implements IContainerClient, IContainerSetup {\n // Routing and definition maps\n private _routing: Map<any, ContainerRouting> = new Map();\n private _functionDefinition: Map<any, IContainerFunctionDefinition> = new Map();\n private _classDefinition: Map<Function, Partial<ContainerOptions>> = new Map();\n\n // Storage maps\n private _functionStorageSingleton: Map<any, any> = new Map();\n private _functionStorageScoped: Map<any, any> = new Map();\n private _classStorageSingleton: Map<Function, any> = new Map();\n private _classStorageScoped: Map<Function, any> = new Map();\n\n // Tracing configuration\n private _enableTracing: boolean = false;\n private _traceRetentionMinutes: number = 5;\n\n // Registration methods\n registerClass<T>(classDefinition: new (...args: any[]) => T, options?: Partial<ContainerOptions>): void {\n // Basic validation\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n console.warn(`[IOC] Attempted to register non-class: ${String(classDefinition)}`);\n // Optional: throw error instead?\n // throw new NotAClassDefinitionError(`Attempted to register non-class: ${String(classDefinition)}`);\n return; // Don't proceed if not a class constructor\n }\n\n // Always clear previous definitions for this exact class constructor\n this.clearDefinitions(classDefinition);\n\n // Always set the routing type so 'isClassDefinition' works\n this._routing.set(classDefinition, ContainerRouting.CLASS);\n\n // Store manual options *only if they are actually provided and have content*\n if (options && Object.keys(options).length > 0) {\n this._classDefinition.set(classDefinition, options);\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with options:`, options);\n } else {\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with no specific options (will use decorators if present).`);\n // If no options are provided, we don't store anything in _classDefinition,\n // effectively clearing any previous manual config and letting decorators take over if present.\n }\n }\n\n registerFunction<T extends (...arg: any[]) => any>(label: any, func: T, options: Partial<ContainerOptions> = {} as any): void {\n this.clearDefinitions(label);\n this._routing.set(label, ContainerRouting.FUNCTIONAL);\n this._functionDefinition.set(label, { function: func, options });\n // console.log(`[IOC RegFunc] Registered function with label ${String(label)} and options:`, options);\n }\n\n // Instance resolution methods - Simplify to just call loadInstance\n instance<T, Sync extends boolean = false>(classDefinition: new (...args: any[]) => T, params: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Basic check upfront\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n throw new NotAClassDefinitionError(`Cannot resolve instance for non-class: ${String(classDefinition)}`);\n }\n return this.loadInstance(classDefinition, params);\n }\n\n get<T, Sync extends boolean = false>(label: any, param: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Just delegate to loadInstance, which handles routing and auto-registration\n return this.loadInstance(label, param);\n }\n\n extend(): IContainerClient & IContainerSetup {\n const childContainer = createContainer() as Container;\n\n // Copy routing and definition maps (share the registration knowledge)\n childContainer._routing = new Map(this._routing);\n childContainer._functionDefinition = new Map(this._functionDefinition);\n childContainer._classDefinition = new Map(this._classDefinition);\n\n // Share singleton storage (singletons are shared across all containers)\n childContainer._functionStorageSingleton = this._functionStorageSingleton;\n childContainer._classStorageSingleton = this._classStorageSingleton;\n\n // Do NOT share scoped storage (new container = new scope)\n // Child gets its own empty scoped storage\n\n // Share tracing configuration\n childContainer._enableTracing = this._enableTracing;\n childContainer._traceRetentionMinutes = this._traceRetentionMinutes;\n\n // console.log('[IOC Extend] Created child container.');\n return childContainer;\n }\n\n // Tracing API\n setTracingEnabled(enabled: boolean): void {\n this._enableTracing = enabled;\n if (enabled && !TraceCleanup.isCleanupRunning()) {\n // Set the trace logger for the ProxyFactory\n setTraceLogger(TraceLoggerModule as any);\n // Start automatic cleanup\n TraceCleanup.start(this._traceRetentionMinutes);\n }\n }\n\n isTracingEnabled(): boolean {\n return this._enableTracing;\n }\n\n setTraceRetentionMinutes(minutes: number): void {\n this._traceRetentionMinutes = Math.max(1, minutes);\n }\n\n getTraces(retentionMinutes?: number): any[] {\n const retention = retentionMinutes ?? this._traceRetentionMinutes;\n return TraceLoggerModule.getRecentTraces(retention);\n }\n\n getAllTraces(): any[] {\n return TraceLoggerModule.getAllTraces();\n }\n\n clearTraces(): void {\n TraceLoggerModule.clearAllTraces();\n }\n\n exportTraces(filepath: string): void {\n const data = TraceLoggerModule.exportTracesToJson();\n const fs = require('fs');\n fs.writeFileSync(filepath, JSON.stringify(data, null, 2));\n }\n\n getTraceStatistics(): any {\n return TraceLoggerModule.getTraceStatistics();\n }\n\n // Private helper methods\n private clearDefinitions(label: any): void {\n this._routing.delete(label);\n this._functionDefinition.delete(label);\n // Only delete from classDefinition if the label is actually a function constructor\n if (typeof label === 'function') {\n this._classDefinition.delete(label);\n }\n }\n\n // Checks if the label is *currently* registered as a class\n private isRegisteredAsClass(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.CLASS;\n }\n\n // Checks if the label is *currently* registered as a function\n private isRegisteredAsFunction(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.FUNCTIONAL;\n }\n\n\n private hasInstance(label: any): boolean {\n const storageType = this.getStorageType(label); // This checks decorators if needed\n\n if (!storageType) {\n // Transient instances are never stored\n return false;\n }\n\n // Determine if it's treated as a class (registered or decorated) *after* getting type\n const isClass = this.isClassType(label); // Use a helper that checks routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.has(label)\n : this._classStorageScoped.has(label);\n } else { // Must be a function if not a class\n return storageType === 'singleton'\n ? this._functionStorageSingleton.has(label)\n : this._functionStorageScoped.has(label);\n }\n }\n\n // Helper to determine if something should be treated as a class (registered or decorated)\n private isClassType(label: any): boolean {\n if (this.isRegisteredAsClass(label)) {\n return true;\n }\n // If not explicitly registered as a class, check if it's a function with @Component\n if (typeof label === 'function' && label.prototype && !this.isRegisteredAsFunction(label)) {\n return getComponentOptions(label) !== null;\n }\n return false;\n }\n\n private getInstance(label: any): any {\n const storageType = this.getStorageType(label); // Checks decorators if needed\n\n if (!storageType) {\n // This should ideally not be reached if called after hasInstance check\n console.error(`[IOC GetInstance] Attempted to get instance for non-stored type: ${String(label)}`);\n throw new InstanceNotCreatedError();\n }\n\n const isClass = this.isClassType(label); // Check routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.get(label)\n : this._classStorageScoped.get(label);\n } else { // Must be a function\n return storageType === 'singleton'\n ? this._functionStorageSingleton.get(label)\n : this._functionStorageScoped.get(label);\n }\n }\n\n private setInstance(label: any, instance: any, storageType?: StorageType): void { // Made storageType non-optional\n const isClass = this.isClassType(label); // Determine type based on routing OR decorator\n\n if (isClass) {\n if (storageType === 'singleton') {\n this._classStorageSingleton.set(label, instance);\n } else if (storageType == 'scoped'){ // storageType === 'scoped'\n this._classStorageScoped.set(label, instance);\n }\n } else { // Must be a function\n if (storageType === 'singleton') {\n this._functionStorageSingleton.set(label, instance);\n } else if(storageType === \"scoped\"){ // storageType === 'scoped'\n this._functionStorageScoped.set(label, instance);\n }\n }\n }\n\n private getStorageType(label: any): StorageType {\n let manualLoadAs: LoadAs | undefined;\n let decoratorScope: LoadAs | undefined;\n const isPotentialClass = typeof label === 'function' && label.prototype;\n\n // Get manual registration options if available\n if (this.isRegisteredAsClass(label)) { // Use helper\n manualLoadAs = this._classDefinition.get(label)?.loadAs;\n } else if (this.isRegisteredAsFunction(label)) { // Use helper\n manualLoadAs = this._functionDefinition.get(label)?.options?.loadAs;\n }\n\n // Get decorator scope only if it's potentially a class *and not explicitly registered as a function*\n if (isPotentialClass && !this.isRegisteredAsFunction(label)) {\n decoratorScope = getScope(label); // Uses getComponentOptions internally\n }\n\n // Determine final scope: Manual > Decorator > Default (Transient)\n const finalScope = manualLoadAs ?? decoratorScope ?? LoadAs.Transient;\n\n if (finalScope === LoadAs.Singleton) {\n return 'singleton';\n } else if (finalScope === LoadAs.Scoped) {\n return 'scoped';\n }else{\n return 'transient'; // Transient\n }\n }\n\n // Central resolution logic - sync-first, returns T or Promise<T>\n protected loadInstance(\n label: any,\n params: ParameterValue<any>[] = [],\n resolutionChain: string[] = [], // Track resolution path\n parentProxyId?: number // For proxy hierarchy tracking\n ): any {\n\n // --- Circular Dependency Check ---\n const currentLabelStr = (typeof label === 'function' && label.name) ? label.name : String(label);\n if (resolutionChain.includes(currentLabelStr)) {\n console.error(`[IOC LoadInstance] Circular dependency detected: ${[...resolutionChain, currentLabelStr].join(' -> ')}`);\n throw new CircularDependencyError([...resolutionChain, currentLabelStr]);\n }\n const nextResolutionChain = [...resolutionChain, currentLabelStr];\n // --- End Circular Dependency Check ---\n\n // --- Handle Parameters ---\n if (label instanceof Parameter) {\n try {\n // Pass a *copy* of params to avoid side effects in resolveParameterValue\n return this.resolveParameterValue(label, [...params]);\n } catch (e) {\n // console.error(`[IOC LoadInstance] Error resolving parameter ${param.toString()}:`, e);\n throw e;\n }\n }\n // --- End Handle Parameters ---\n\n // --- Handle Scoped Container Injection ---\n if (label === SCOPED_CONTAINER) {\n return this;\n }\n // --- End Handle Scoped Container Injection ---\n\n // --- Check Explicit Registrations ---\n if (this.isRegisteredAsClass(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered class: ${currentLabelStr}`);\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n if (this.isRegisteredAsFunction(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered function: ${currentLabelStr}`);\n return this.loadFunctionInstance(label, params, nextResolutionChain);\n }\n // --- End Check Explicit Registrations ---\n\n\n // --- Attempt Auto-Registration/Resolution for Decorated Classes ---\n if (typeof label === 'function' && label.prototype) {\n const componentOptions = getComponentOptions(label); // Check for @Component\n if (componentOptions !== null) {\n // console.log(`[IOC LoadInstance] Auto-resolving @Component class: ${currentLabelStr}`);\n // Set routing *now* so subsequent internal checks work correctly\n if (!this._routing.has(label)) { // Only set if not already set\n this._routing.set(label, ContainerRouting.CLASS);\n // console.log(`[IOC LoadInstance] Set routing for auto-resolved class: ${currentLabelStr}`);\n }\n // Proceed to load it as a class\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n }\n // --- End Auto-Registration ---\n\n\n // --- Dependency Not Found ---\n console.error(`[IOC LoadInstance] Dependency not found and cannot be resolved: ${currentLabelStr}`);\n throw new DependencyNotFoundError(currentLabelStr);\n }\n\n\n private resolveParameterValue(param: Parameter, params: ParameterValue<any>[]): any { // No mutation\n // Find the *last* provided value for the parameter\n const valueContainer = [...params].reverse().find((p) => p.belongsTo(param));\n if (!valueContainer) {\n // console.error(`[IOC ResolveParam] Parameter not found: ${param.toString()}`);\n throw new ParameterNotFoundError(param.toString());\n }\n // console.log(`[IOC ResolveParam] Resolved parameter ${param.toString()}`);\n return valueContainer.value;\n }\n\n private loadClassInstance(\n classDefinition: any, // Should be a class constructor here\n params: ParameterValue<any>[],\n resolutionChain: string[],\n parentProxyId?: number\n ): any {\n const storageType = this.getStorageType(classDefinition);\n const className = classDefinition.name || '[Anonymous Class]';\n\n // Check storage first (may be sync value or Promise)\n if (storageType && this.hasInstance(classDefinition)) {\n const instance = this.getInstance(classDefinition);\n // console.log(`[IOC LoadClass] Found existing ${storageType} instance for ${className}. IsPromise: ${isPromise(instance)}`);\n return instance;\n }\n // console.log(`[IOC LoadClass] Creating new ${storageType || 'transient'} instance for ${className}`);\n\n // --- Determine Dependencies ---\n const manualOptions = this._classDefinition.get(classDefinition) as ContainerOptions | undefined;\n let dependenciesToResolve: any[];\n\n if (manualOptions?.param && Array.isArray(manualOptions.param)) {\n dependenciesToResolve = manualOptions.param;\n // console.log(`[IOC LoadClass] Using manual dependencies for ${className}`);\n } else {\n // Use decorator-derived dependencies\n dependenciesToResolve = getResolvedDependencies(classDefinition);\n // console.log(`[IOC LoadClass] Using decorator/reflected dependencies for ${className}:`, dependenciesToResolve.map(d => typeof d === 'function' ? d.name : String(d)));\n }\n // --- End Determine Dependencies ---\n\n // Reserve a proxy ID if tracing is enabled\n let futureProxyId: number | undefined;\n if (this._enableTracing) {\n futureProxyId = reserveProxyId();\n }\n\n // --- Resolve Dependencies (sync-first) ---\n const paramsCopy = [...params];\n const resolvedDependencies: any[] = [];\n let hasAsyncDependency = false;\n\n // Resolve each dependency and check if any return Promises\n for (const dependencyIdentifier of dependenciesToResolve) {\n const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain, futureProxyId);\n resolvedDependencies.push(resolved);\n if (isPromise(resolved)) {\n hasAsyncDependency = true;\n }\n }\n\n // Helper to instantiate the class\n const instantiate = (deps: any[]): any => {\n try {\n const instance = new classDefinition(...deps);\n\n // Wrap with proxy if tracing is enabled\n if (this._enableTracing && futureProxyId !== undefined) {\n return wrapWithProxy(instance, className, parentProxyId, futureProxyId);\n }\n return instance;\n } catch (err: any) {\n console.error(`[IOC LoadClass] Error during instantiation of ${className}: ${err.message}`, err.stack);\n throw err;\n }\n };\n\n // --- Sync Path: All dependencies resolved synchronously ---\n if (!hasAsyncDependency) {\n const instance = instantiate(resolvedDependencies);\n\n // Store if singleton/scoped\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n }\n\n // --- Async Path: At least one dependency is a Promise ---\n const asyncInstance = Promise.all(resolvedDependencies)\n .then((deps) => {\n const instance = instantiate(deps);\n\n // Store if singleton/scoped (overwrite the promise with the instance)\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n })\n .catch((error) => {\n console.error(`[IOC LoadClass] Failed to resolve one or more dependencies for ${className}:`, error);\n // Clean up stored promise on failure\n if (storageType && this.isRegisteredAsClass(classDefinition)) {\n if (storageType === 'singleton') this._classStorageSingleton.delete(classDefinition);\n if (storageType === 'scoped') this._classStorageScoped.delete(classDefinition);\n }\n throw error;\n });\n\n // Store the promise for singleton/scoped to handle concurrent requests\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, asyncInstance, storageType);\n }\n\n return asyncInstance;\n }\n\n private loadFunctionInstance(\n funcLabel: any,\n params: ParameterValue<any>[],\n resolutionChain: string[]\n ): Promise<any> { // Always return Promise<any> since this is an async function\n const functionConfig = this._functionDefinition.get(funcLabel)!; // Assumed to exist by caller\n const storageType = this.getStorageType(funcLabel); // Only uses manual options for functions\n const labelStr = String(funcLabel);\n\n // Check storage first\n if (storageType && this.hasInstance(funcLabel)) {\n const instance = this.getInstance(funcLabel);\n // console.log(`[IOC LoadFunc] Found existing ${storageType} instance for ${labelStr}. IsPromise: ${isPromise(instance)}`);\n return instance;\n }\n // console.log(`[IOC LoadFunc] Creating new ${storageType || 'transient'} instance for ${labelStr}`);\n\n const ioc_func = functionConfig.function;\n const options = functionConfig.options;\n const dependenciesToResolve: any[] = options?.param || [];\n\n // --- Resolve Dependencies ---\n const paramsCopy = [...params]; // Create a copy\n const resolutionPromises = dependenciesToResolve.map(dependencyIdentifier =>\n this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain)\n );\n\n let finalInstance = Promise.all(resolutionPromises).catch((error)=>{\n console.error(`[IOC LoadFunc] Failed to resolve dependencies for function ${labelStr}:`, error);\n // Clean up potential partial storage\n if (storageType && this.isRegisteredAsFunction(funcLabel)) {\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n }\n throw error;\n }).then(async(resolvedArgs)=>{\n let instancePromise: Promise<any> | undefined;\n if (storageType && !this.hasInstance(funcLabel)) {\n instancePromise = (async () => {\n try {\n // console.log(`[IOC LoadFunc] Invoking ${labelStr} with ${resolvedArgs.length} args.`);\n const result = await ioc_func.apply(null, resolvedArgs); // Await in case function is async\n // Overwrite stored promise with actual result\n this.setInstance(funcLabel, result, storageType);\n // console.log(`[IOC LoadFunc] Stored actual ${storageType} instance for ${labelStr}`);\n return result;\n } catch (err: any) {\n console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);\n // Clean up stored promise on failure\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n throw err;\n }\n })();\n // console.log(`[IOC LoadFunc] Storing promise for concurrent requests (${storageType}) for ${labelStr}`);\n this.setInstance(funcLabel, instancePromise, storageType);\n } else {\n // Transient or already resolved from storage check\n instancePromise = (async () => {\n try {\n // console.log(`[IOC LoadFunc] Invoking transient ${labelStr} with ${resolvedArgs.length} args.`);\n const result = await ioc_func.apply(null, resolvedArgs); // Await in case function is async\n // No storing for transient\n return result;\n } catch (err: any) {\n console.error(`[IOC LoadFunc] Error executing transient function ${labelStr}: ${err.message}`, err.stack);\n throw err;\n }\n })();\n }\n // --- End Invoke Function ---\n\n return await instancePromise; // Return the final (awaited) result\n });\n\n if(storageType && storageType !== 'transient'){\n this.setInstance(funcLabel, finalInstance, storageType); // Store the promise\n }\n\n return finalInstance;\n }\n}\n\n// Helper functions\nexport function isPromise(obj: any): obj is Promise<any> {\n // Simplified check - more robust check might be needed depending on environment\n return !!obj && typeof obj.then === 'function';\n}\n\nexport function createContainer(): IContainerClient & IContainerSetup {\n return new Container();\n}\n"],"mappings":"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","names":["ContainerRouting"]}
|
|
1
|
+
{"version":3,"sources":["../../../framework/implementation/Container.ts"],"sourcesContent":["import 'reflect-metadata'; // Ensure polyfill is loaded conceptually\nimport type { ContainerOptions, IContainerClient, IContainerFunctionDefinition, IContainerSetup } from \"../interface/Container.js\";\nimport { LoadAs } from \"./LoadAs.js\";\nimport { Parameter } from \"./Parameter.js\";\nimport type { ParameterValue } from \"./Parameter.js\";\nimport { NotAClassDefinitionError, ParameterNotFoundError, DependencyNotFoundError, InstanceNotCreatedError, CircularDependencyError } from \"../errors/ContainerErrors.js\";\nimport {\n getScope,\n getComponentOptions, // Use helper\n getResolvedDependencies // Use helper\n} from './DecoratorSupport'; // Assume helpers exist or create them\nimport { wrapWithProxy, setTraceLogger, reserveProxyId } from \"./ProxyFactory.js\";\nimport * as TraceLoggerModule from \"./TraceLogger.js\";\nimport { TraceCleanup } from \"./TraceCleanup.js\";\n\n/**\n * A special injection token that resolves to the current scoped container.\n * Use this as a dependency in param arrays to have the container inject itself.\n * This allows provider classes to resolve additional dependencies on demand.\n */\nexport const SCOPED_CONTAINER = Symbol.for(\"ioc:scoped-container\");\n\nenum ContainerRouting {\n FUNCTIONAL = \"FUNCTIONAL\",\n CLASS = \"CLASS\"\n // No need for COMPONENT route, just check metadata if CLASS/FUNCTIONAL fails\n}\n\ntype StorageType = 'singleton' | 'scoped' | 'transient';\n\nexport class Container implements IContainerClient, IContainerSetup {\n // Routing and definition maps\n private _routing: Map<any, ContainerRouting> = new Map();\n private _functionDefinition: Map<any, IContainerFunctionDefinition> = new Map();\n private _classDefinition: Map<Function, Partial<ContainerOptions>> = new Map();\n\n // Storage maps\n private _functionStorageSingleton: Map<any, any> = new Map();\n private _functionStorageScoped: Map<any, any> = new Map();\n private _classStorageSingleton: Map<Function, any> = new Map();\n private _classStorageScoped: Map<Function, any> = new Map();\n\n // Tracing configuration\n private _enableTracing: boolean = false;\n private _traceRetentionMinutes: number = 5;\n\n // Registration methods\n registerClass<T>(classDefinition: new (...args: any[]) => T, options?: Partial<ContainerOptions>): void {\n // Basic validation\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n console.warn(`[IOC] Attempted to register non-class: ${String(classDefinition)}`);\n // Optional: throw error instead?\n // throw new NotAClassDefinitionError(`Attempted to register non-class: ${String(classDefinition)}`);\n return; // Don't proceed if not a class constructor\n }\n\n // Always clear previous definitions for this exact class constructor\n this.clearDefinitions(classDefinition);\n\n // Always set the routing type so 'isClassDefinition' works\n this._routing.set(classDefinition, ContainerRouting.CLASS);\n\n // Store manual options *only if they are actually provided and have content*\n if (options && Object.keys(options).length > 0) {\n this._classDefinition.set(classDefinition, options);\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with options:`, options);\n } else {\n // console.log(`[IOC RegClass] Manually registered ${classDefinition.name} with no specific options (will use decorators if present).`);\n // If no options are provided, we don't store anything in _classDefinition,\n // effectively clearing any previous manual config and letting decorators take over if present.\n }\n }\n\n registerFunction<T extends (...arg: any[]) => any>(label: any, func: T, options: Partial<ContainerOptions> = {} as any): void {\n this.clearDefinitions(label);\n this._routing.set(label, ContainerRouting.FUNCTIONAL);\n this._functionDefinition.set(label, { function: func, options });\n // console.log(`[IOC RegFunc] Registered function with label ${String(label)} and options:`, options);\n }\n\n // Instance resolution methods - Simplify to just call loadInstance\n instance<T, Sync extends boolean = false>(classDefinition: new (...args: any[]) => T, params: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Basic check upfront\n if (typeof classDefinition !== 'function' || !classDefinition.prototype) {\n throw new NotAClassDefinitionError(`Cannot resolve instance for non-class: ${String(classDefinition)}`);\n }\n return this.loadInstance(classDefinition, params);\n }\n\n get<T, Sync extends boolean = false>(label: any, param: ParameterValue<any>[] = []): Sync extends true ? T : Promise<T> | T {\n // Just delegate to loadInstance, which handles routing and auto-registration\n return this.loadInstance(label, param);\n }\n\n extend(): IContainerClient & IContainerSetup {\n const childContainer = createContainer() as Container;\n\n // Copy routing and definition maps (share the registration knowledge)\n childContainer._routing = new Map(this._routing);\n childContainer._functionDefinition = new Map(this._functionDefinition);\n childContainer._classDefinition = new Map(this._classDefinition);\n\n // Share singleton storage (singletons are shared across all containers)\n childContainer._functionStorageSingleton = this._functionStorageSingleton;\n childContainer._classStorageSingleton = this._classStorageSingleton;\n\n // Do NOT share scoped storage (new container = new scope)\n // Child gets its own empty scoped storage\n\n // Share tracing configuration\n childContainer._enableTracing = this._enableTracing;\n childContainer._traceRetentionMinutes = this._traceRetentionMinutes;\n\n // console.log('[IOC Extend] Created child container.');\n return childContainer;\n }\n\n // Tracing API\n setTracingEnabled(enabled: boolean): void {\n this._enableTracing = enabled;\n if (enabled && !TraceCleanup.isCleanupRunning()) {\n // Set the trace logger for the ProxyFactory\n setTraceLogger(TraceLoggerModule as any);\n // Start automatic cleanup\n TraceCleanup.start(this._traceRetentionMinutes);\n }\n }\n\n isTracingEnabled(): boolean {\n return this._enableTracing;\n }\n\n setTraceRetentionMinutes(minutes: number): void {\n this._traceRetentionMinutes = Math.max(1, minutes);\n }\n\n getTraces(retentionMinutes?: number): any[] {\n const retention = retentionMinutes ?? this._traceRetentionMinutes;\n return TraceLoggerModule.getRecentTraces(retention);\n }\n\n getAllTraces(): any[] {\n return TraceLoggerModule.getAllTraces();\n }\n\n clearTraces(): void {\n TraceLoggerModule.clearAllTraces();\n }\n\n exportTraces(filepath: string): void {\n const data = TraceLoggerModule.exportTracesToJson();\n const fs = require('fs');\n fs.writeFileSync(filepath, JSON.stringify(data, null, 2));\n }\n\n getTraceStatistics(): any {\n return TraceLoggerModule.getTraceStatistics();\n }\n\n // Private helper methods\n private clearDefinitions(label: any): void {\n this._routing.delete(label);\n this._functionDefinition.delete(label);\n // Only delete from classDefinition if the label is actually a function constructor\n if (typeof label === 'function') {\n this._classDefinition.delete(label);\n }\n }\n\n // Checks if the label is *currently* registered as a class\n private isRegisteredAsClass(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.CLASS;\n }\n\n // Checks if the label is *currently* registered as a function\n private isRegisteredAsFunction(label: any): boolean {\n return this._routing.get(label) === ContainerRouting.FUNCTIONAL;\n }\n\n\n private hasInstance(label: any): boolean {\n const storageType = this.getStorageType(label); // This checks decorators if needed\n\n if (!storageType) {\n // Transient instances are never stored\n return false;\n }\n\n // Determine if it's treated as a class (registered or decorated) *after* getting type\n const isClass = this.isClassType(label); // Use a helper that checks routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.has(label)\n : this._classStorageScoped.has(label);\n } else { // Must be a function if not a class\n return storageType === 'singleton'\n ? this._functionStorageSingleton.has(label)\n : this._functionStorageScoped.has(label);\n }\n }\n\n // Helper to determine if something should be treated as a class (registered or decorated)\n private isClassType(label: any): boolean {\n if (this.isRegisteredAsClass(label)) {\n return true;\n }\n // If not explicitly registered as a class, check if it's a function with @Component\n if (typeof label === 'function' && label.prototype && !this.isRegisteredAsFunction(label)) {\n return getComponentOptions(label) !== null;\n }\n return false;\n }\n\n private getInstance(label: any): any {\n const storageType = this.getStorageType(label); // Checks decorators if needed\n\n if (!storageType) {\n // This should ideally not be reached if called after hasInstance check\n console.error(`[IOC GetInstance] Attempted to get instance for non-stored type: ${String(label)}`);\n throw new InstanceNotCreatedError();\n }\n\n const isClass = this.isClassType(label); // Check routing OR decorator\n\n if (isClass) {\n return storageType === 'singleton'\n ? this._classStorageSingleton.get(label)\n : this._classStorageScoped.get(label);\n } else { // Must be a function\n return storageType === 'singleton'\n ? this._functionStorageSingleton.get(label)\n : this._functionStorageScoped.get(label);\n }\n }\n\n private setInstance(label: any, instance: any, storageType?: StorageType): void { // Made storageType non-optional\n const isClass = this.isClassType(label); // Determine type based on routing OR decorator\n\n if (isClass) {\n if (storageType === 'singleton') {\n this._classStorageSingleton.set(label, instance);\n } else if (storageType == 'scoped'){ // storageType === 'scoped'\n this._classStorageScoped.set(label, instance);\n }\n } else { // Must be a function\n if (storageType === 'singleton') {\n this._functionStorageSingleton.set(label, instance);\n } else if(storageType === \"scoped\"){ // storageType === 'scoped'\n this._functionStorageScoped.set(label, instance);\n }\n }\n }\n\n private getStorageType(label: any): StorageType {\n let manualLoadAs: LoadAs | undefined;\n let decoratorScope: LoadAs | undefined;\n const isPotentialClass = typeof label === 'function' && label.prototype;\n\n // Get manual registration options if available\n if (this.isRegisteredAsClass(label)) { // Use helper\n manualLoadAs = this._classDefinition.get(label)?.loadAs;\n } else if (this.isRegisteredAsFunction(label)) { // Use helper\n manualLoadAs = this._functionDefinition.get(label)?.options?.loadAs;\n }\n\n // Get decorator scope only if it's potentially a class *and not explicitly registered as a function*\n if (isPotentialClass && !this.isRegisteredAsFunction(label)) {\n decoratorScope = getScope(label); // Uses getComponentOptions internally\n }\n\n // Determine final scope: Manual > Decorator > Default (Transient)\n const finalScope = manualLoadAs ?? decoratorScope ?? LoadAs.Transient;\n\n if (finalScope === LoadAs.Singleton) {\n return 'singleton';\n } else if (finalScope === LoadAs.Scoped) {\n return 'scoped';\n }else{\n return 'transient'; // Transient\n }\n }\n\n // Central resolution logic - sync-first, returns T or Promise<T>\n protected loadInstance(\n label: any,\n params: ParameterValue<any>[] = [],\n resolutionChain: string[] = [], // Track resolution path\n parentProxyId?: number // For proxy hierarchy tracking\n ): any {\n\n // --- Circular Dependency Check ---\n const currentLabelStr = (typeof label === 'function' && label.name) ? label.name : String(label);\n if (resolutionChain.includes(currentLabelStr)) {\n console.error(`[IOC LoadInstance] Circular dependency detected: ${[...resolutionChain, currentLabelStr].join(' -> ')}`);\n throw new CircularDependencyError([...resolutionChain, currentLabelStr]);\n }\n const nextResolutionChain = [...resolutionChain, currentLabelStr];\n // --- End Circular Dependency Check ---\n\n // --- Handle Parameters ---\n if (label instanceof Parameter) {\n try {\n // Pass a *copy* of params to avoid side effects in resolveParameterValue\n return this.resolveParameterValue(label, [...params]);\n } catch (e) {\n // console.error(`[IOC LoadInstance] Error resolving parameter ${param.toString()}:`, e);\n throw e;\n }\n }\n // --- End Handle Parameters ---\n\n // --- Handle Scoped Container Injection ---\n if (label === SCOPED_CONTAINER) {\n return this;\n }\n // --- End Handle Scoped Container Injection ---\n\n // --- Check Explicit Registrations ---\n if (this.isRegisteredAsClass(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered class: ${currentLabelStr}`);\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n if (this.isRegisteredAsFunction(label)) {\n // console.log(`[IOC LoadInstance] Resolving explicitly registered function: ${currentLabelStr}`);\n return this.loadFunctionInstance(label, params, nextResolutionChain);\n }\n // --- End Check Explicit Registrations ---\n\n\n // --- Attempt Auto-Registration/Resolution for Decorated Classes ---\n if (typeof label === 'function' && label.prototype) {\n const componentOptions = getComponentOptions(label); // Check for @Component\n if (componentOptions !== null) {\n // console.log(`[IOC LoadInstance] Auto-resolving @Component class: ${currentLabelStr}`);\n // Set routing *now* so subsequent internal checks work correctly\n if (!this._routing.has(label)) { // Only set if not already set\n this._routing.set(label, ContainerRouting.CLASS);\n // console.log(`[IOC LoadInstance] Set routing for auto-resolved class: ${currentLabelStr}`);\n }\n // Proceed to load it as a class\n return this.loadClassInstance(label, params, nextResolutionChain, parentProxyId);\n }\n }\n // --- End Auto-Registration ---\n\n\n // --- Dependency Not Found ---\n console.error(`[IOC LoadInstance] Dependency not found and cannot be resolved: ${currentLabelStr}`);\n throw new DependencyNotFoundError(currentLabelStr);\n }\n\n\n private resolveParameterValue(param: Parameter, params: ParameterValue<any>[]): any { // No mutation\n // Find the *last* provided value for the parameter\n const valueContainer = [...params].reverse().find((p) => p.belongsTo(param));\n if (!valueContainer) {\n // console.error(`[IOC ResolveParam] Parameter not found: ${param.toString()}`);\n throw new ParameterNotFoundError(param.toString());\n }\n // console.log(`[IOC ResolveParam] Resolved parameter ${param.toString()}`);\n return valueContainer.value;\n }\n\n private loadClassInstance(\n classDefinition: any, // Should be a class constructor here\n params: ParameterValue<any>[],\n resolutionChain: string[],\n parentProxyId?: number\n ): any {\n const storageType = this.getStorageType(classDefinition);\n const className = classDefinition.name || '[Anonymous Class]';\n\n // Check storage first (may be sync value or Promise)\n if (storageType && this.hasInstance(classDefinition)) {\n const instance = this.getInstance(classDefinition);\n // console.log(`[IOC LoadClass] Found existing ${storageType} instance for ${className}. IsPromise: ${isPromise(instance)}`);\n return instance;\n }\n // console.log(`[IOC LoadClass] Creating new ${storageType || 'transient'} instance for ${className}`);\n\n // --- Determine Dependencies ---\n const manualOptions = this._classDefinition.get(classDefinition) as ContainerOptions | undefined;\n let dependenciesToResolve: any[];\n\n if (manualOptions?.param && Array.isArray(manualOptions.param)) {\n dependenciesToResolve = manualOptions.param;\n // console.log(`[IOC LoadClass] Using manual dependencies for ${className}`);\n } else {\n // Use decorator-derived dependencies\n dependenciesToResolve = getResolvedDependencies(classDefinition);\n // console.log(`[IOC LoadClass] Using decorator/reflected dependencies for ${className}:`, dependenciesToResolve.map(d => typeof d === 'function' ? d.name : String(d)));\n }\n // --- End Determine Dependencies ---\n\n // Reserve a proxy ID if tracing is enabled\n let futureProxyId: number | undefined;\n if (this._enableTracing) {\n futureProxyId = reserveProxyId();\n }\n\n // --- Resolve Dependencies (sync-first) ---\n const paramsCopy = [...params];\n const resolvedDependencies: any[] = [];\n let hasAsyncDependency = false;\n\n // Resolve each dependency and check if any return Promises\n for (const dependencyIdentifier of dependenciesToResolve) {\n const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain, futureProxyId);\n resolvedDependencies.push(resolved);\n if (isPromise(resolved)) {\n hasAsyncDependency = true;\n }\n }\n\n // Helper to instantiate the class\n const instantiate = (deps: any[]): any => {\n try {\n const instance = new classDefinition(...deps);\n\n // Wrap with proxy if tracing is enabled\n if (this._enableTracing && futureProxyId !== undefined) {\n return wrapWithProxy(instance, className, parentProxyId, futureProxyId);\n }\n return instance;\n } catch (err: any) {\n console.error(`[IOC LoadClass] Error during instantiation of ${className}: ${err.message}`, err.stack);\n throw err;\n }\n };\n\n // --- Sync Path: All dependencies resolved synchronously ---\n if (!hasAsyncDependency) {\n const instance = instantiate(resolvedDependencies);\n\n // Store if singleton/scoped\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n }\n\n // --- Async Path: At least one dependency is a Promise ---\n const asyncInstance = Promise.all(resolvedDependencies)\n .then((deps) => {\n const instance = instantiate(deps);\n\n // Store if singleton/scoped (overwrite the promise with the instance)\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, instance, storageType);\n }\n return instance;\n })\n .catch((error) => {\n console.error(`[IOC LoadClass] Failed to resolve one or more dependencies for ${className}:`, error);\n // Clean up stored promise on failure\n if (storageType && this.isRegisteredAsClass(classDefinition)) {\n if (storageType === 'singleton') this._classStorageSingleton.delete(classDefinition);\n if (storageType === 'scoped') this._classStorageScoped.delete(classDefinition);\n }\n throw error;\n });\n\n // Store the promise for singleton/scoped to handle concurrent requests\n if (storageType && storageType !== 'transient') {\n this.setInstance(classDefinition, asyncInstance, storageType);\n }\n\n return asyncInstance;\n }\n\n private loadFunctionInstance(\n funcLabel: any,\n params: ParameterValue<any>[],\n resolutionChain: string[]\n ): any {\n const functionConfig = this._functionDefinition.get(funcLabel)!;\n const storageType = this.getStorageType(funcLabel);\n const labelStr = String(funcLabel);\n\n // Check storage first\n if (storageType && this.hasInstance(funcLabel)) {\n return this.getInstance(funcLabel);\n }\n\n const ioc_func = functionConfig.function;\n const options = functionConfig.options;\n const dependenciesToResolve: any[] = options?.param || [];\n\n // --- Resolve Dependencies ---\n const paramsCopy = [...params];\n const resolvedDependencies: any[] = [];\n let hasAsyncDependency = false;\n\n for (const dependencyIdentifier of dependenciesToResolve) {\n const resolved = this.loadInstance(dependencyIdentifier, paramsCopy, resolutionChain);\n resolvedDependencies.push(resolved);\n if (isPromise(resolved)) {\n hasAsyncDependency = true;\n }\n }\n\n // Helper to invoke the factory and store the result\n const invoke = (deps: any[]): any => {\n try {\n const result = ioc_func.apply(null, deps);\n\n // If factory returns a promise, handle async\n if (isPromise(result)) {\n return (result as Promise<any>).then((resolved) => {\n if (storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, resolved, storageType);\n }\n return resolved;\n }).catch((err: any) => {\n console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n throw err;\n });\n }\n\n // Sync result\n if (storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, result, storageType);\n }\n return result;\n } catch (err: any) {\n console.error(`[IOC LoadFunc] Error executing function ${labelStr}: ${err.message}`, err.stack);\n throw err;\n }\n };\n\n // --- Sync Path: All dependencies resolved synchronously ---\n if (!hasAsyncDependency) {\n const instance = invoke(resolvedDependencies);\n if (isPromise(instance) && storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, instance, storageType);\n }\n return instance;\n }\n\n // --- Async Path: At least one dependency is a Promise ---\n const asyncInstance = Promise.all(resolvedDependencies)\n .then((deps) => {\n const instance = invoke(deps);\n return instance;\n })\n .catch((error) => {\n console.error(`[IOC LoadFunc] Failed to resolve dependencies for function ${labelStr}:`, error);\n if (storageType === 'singleton') this._functionStorageSingleton.delete(funcLabel);\n if (storageType === 'scoped') this._functionStorageScoped.delete(funcLabel);\n throw error;\n });\n\n if (storageType && storageType !== 'transient') {\n this.setInstance(funcLabel, asyncInstance, storageType);\n }\n\n return asyncInstance;\n }\n}\n\n// Helper functions\nexport function isPromise(obj: any): obj is Promise<any> {\n // Simplified check - more robust check might be needed depending on environment\n return !!obj && typeof obj.then === 'function';\n}\n\nexport function createContainer(): IContainerClient & IContainerSetup {\n return new Container();\n}\n"],"mappings":"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","names":["ContainerRouting"]}
|