@hkdigital/lib-core 0.4.52 → 0.4.54
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/services/index.d.ts
CHANGED
|
@@ -1,3 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Create a getService function with a preset manager
|
|
3
|
+
*
|
|
4
|
+
* @param {import('./service-manager/ServiceManager.js').default} manager
|
|
5
|
+
* ServiceManager instance to use
|
|
6
|
+
*
|
|
7
|
+
* @returns {<T>(serviceName: string) => T} getService function with preset manager
|
|
8
|
+
*/
|
|
9
|
+
export function createGetService(manager: import("./service-manager/ServiceManager.js").default): <T>(serviceName: string) => T;
|
|
1
10
|
export { default as ServiceBase } from "./service-base/ServiceBase.js";
|
|
2
11
|
export { default as ServiceManager } from "./service-manager/ServiceManager.js";
|
|
3
12
|
export * from "./service-base/constants.js";
|
package/dist/services/index.js
CHANGED
|
@@ -3,3 +3,33 @@ export { default as ServiceManager } from './service-manager/ServiceManager.js';
|
|
|
3
3
|
|
|
4
4
|
export * from './service-base/constants.js';
|
|
5
5
|
export * from './service-manager/constants.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Create a getService function with a preset manager
|
|
9
|
+
*
|
|
10
|
+
* @param {import('./service-manager/ServiceManager.js').default} manager
|
|
11
|
+
* ServiceManager instance to use
|
|
12
|
+
*
|
|
13
|
+
* @returns {<T>(serviceName: string) => T} getService function with preset manager
|
|
14
|
+
*/
|
|
15
|
+
export function createGetService(manager) {
|
|
16
|
+
/**
|
|
17
|
+
* Get a typed service instance from the preset manager
|
|
18
|
+
*
|
|
19
|
+
* @template T
|
|
20
|
+
* @param {string} serviceName - Name of the service to retrieve
|
|
21
|
+
*
|
|
22
|
+
* @returns {T} The service instance cast to the specified type
|
|
23
|
+
*
|
|
24
|
+
* @throws {Error} If service is not found
|
|
25
|
+
*/
|
|
26
|
+
return function getService(serviceName) {
|
|
27
|
+
const service = manager.get(serviceName);
|
|
28
|
+
|
|
29
|
+
if (!service) {
|
|
30
|
+
throw new Error(`Service [${serviceName}] not found`);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return /** @type {T} */ (service);
|
|
34
|
+
};
|
|
35
|
+
}
|
|
@@ -84,6 +84,17 @@ export class ServiceManager extends EventEmitter {
|
|
|
84
84
|
* @returns {T|undefined} Service instance or undefined if not found
|
|
85
85
|
*/
|
|
86
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
|
*
|
|
@@ -295,6 +295,26 @@ export class ServiceManager extends EventEmitter {
|
|
|
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
|
*
|