@hkdigital/lib-core 0.4.51 → 0.4.53
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.
|
@@ -81,9 +81,20 @@ export class ServiceManager extends EventEmitter {
|
|
|
81
81
|
* @template {import('../service-base/typedef.js').ServiceInstance} T
|
|
82
82
|
* @param {string} name - Service name
|
|
83
83
|
*
|
|
84
|
-
* @returns {T|
|
|
84
|
+
* @returns {T|undefined} Service instance or undefined if not found
|
|
85
85
|
*/
|
|
86
|
-
get<T extends import("../service-base/typedef.js").ServiceInstance>(name: string): T |
|
|
86
|
+
get<T extends import("../service-base/typedef.js").ServiceInstance>(name: string): T | undefined;
|
|
87
|
+
/**
|
|
88
|
+
* Get or create a service instance with error throwing
|
|
89
|
+
*
|
|
90
|
+
* @template {import('../service-base/typedef.js').ServiceInstance} T
|
|
91
|
+
* @param {string} name - Service name
|
|
92
|
+
*
|
|
93
|
+
* @returns {T} Service instance
|
|
94
|
+
*
|
|
95
|
+
* @throws {Error} If service is not found or cannot be created
|
|
96
|
+
*/
|
|
97
|
+
getService<T extends import("../service-base/typedef.js").ServiceInstance>(name: string): T;
|
|
87
98
|
/**
|
|
88
99
|
* Configure a service
|
|
89
100
|
*
|
|
@@ -261,7 +261,7 @@ export class ServiceManager extends EventEmitter {
|
|
|
261
261
|
* @template {import('../service-base/typedef.js').ServiceInstance} T
|
|
262
262
|
* @param {string} name - Service name
|
|
263
263
|
*
|
|
264
|
-
* @returns {T|
|
|
264
|
+
* @returns {T|undefined} Service instance or undefined if not found
|
|
265
265
|
*/
|
|
266
266
|
get(name) {
|
|
267
267
|
// @throws service not found
|
|
@@ -288,13 +288,33 @@ export class ServiceManager extends EventEmitter {
|
|
|
288
288
|
`Failed to create instance for '${name}'`,
|
|
289
289
|
/** @type {Error} */ (error)
|
|
290
290
|
);
|
|
291
|
-
return
|
|
291
|
+
return undefined;
|
|
292
292
|
}
|
|
293
293
|
}
|
|
294
294
|
|
|
295
295
|
return entry.instance;
|
|
296
296
|
}
|
|
297
297
|
|
|
298
|
+
/**
|
|
299
|
+
* Get or create a service instance with error throwing
|
|
300
|
+
*
|
|
301
|
+
* @template {import('../service-base/typedef.js').ServiceInstance} T
|
|
302
|
+
* @param {string} name - Service name
|
|
303
|
+
*
|
|
304
|
+
* @returns {T} Service instance
|
|
305
|
+
*
|
|
306
|
+
* @throws {Error} If service is not found or cannot be created
|
|
307
|
+
*/
|
|
308
|
+
getService(name) {
|
|
309
|
+
const service = this.get(name);
|
|
310
|
+
|
|
311
|
+
if (!service) {
|
|
312
|
+
throw new Error(`Service [${name}] not found or could not be created`);
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
return /** @type {T} */ (service);
|
|
316
|
+
}
|
|
317
|
+
|
|
298
318
|
/**
|
|
299
319
|
* Configure a service
|
|
300
320
|
*
|