@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.
@@ -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";
@@ -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
  *
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hkdigital/lib-core",
3
- "version": "0.4.52",
3
+ "version": "0.4.54",
4
4
  "author": {
5
5
  "name": "HKdigital",
6
6
  "url": "https://hkdigital.nl"