@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|null} Service instance or null if not found
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 | null;
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|null} Service instance or null if not found
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 null;
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
  *
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hkdigital/lib-core",
3
- "version": "0.4.51",
3
+ "version": "0.4.53",
4
4
  "author": {
5
5
  "name": "HKdigital",
6
6
  "url": "https://hkdigital.nl"