@rsdk/nats.kv 5.4.0-next.2

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.
Files changed (58) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/constants.d.ts +1 -0
  3. package/dist/constants.js +5 -0
  4. package/dist/constants.js.map +1 -0
  5. package/dist/index.d.ts +5 -0
  6. package/dist/index.js +26 -0
  7. package/dist/index.js.map +1 -0
  8. package/dist/inject-kv-service.decorator.d.ts +2 -0
  9. package/dist/inject-kv-service.decorator.js +19 -0
  10. package/dist/inject-kv-service.decorator.js.map +1 -0
  11. package/dist/interfaces/nats-kv-entry-meta.interface.d.ts +6 -0
  12. package/dist/interfaces/nats-kv-entry-meta.interface.js +3 -0
  13. package/dist/interfaces/nats-kv-entry-meta.interface.js.map +1 -0
  14. package/dist/interfaces/nats-kv-entry.interface.d.ts +6 -0
  15. package/dist/interfaces/nats-kv-entry.interface.js +3 -0
  16. package/dist/interfaces/nats-kv-entry.interface.js.map +1 -0
  17. package/dist/kv-storage.d.ts +23 -0
  18. package/dist/kv-storage.js +80 -0
  19. package/dist/kv-storage.js.map +1 -0
  20. package/dist/nats-kv-module.generator.d.ts +5 -0
  21. package/dist/nats-kv-module.generator.js +30 -0
  22. package/dist/nats-kv-module.generator.js.map +1 -0
  23. package/dist/nats-kv.module.d.ts +9 -0
  24. package/dist/nats-kv.module.js +63 -0
  25. package/dist/nats-kv.module.js.map +1 -0
  26. package/dist/nats-kv.service.d.ts +31 -0
  27. package/dist/nats-kv.service.js +101 -0
  28. package/dist/nats-kv.service.js.map +1 -0
  29. package/dist/tokens.fn.d.ts +2 -0
  30. package/dist/tokens.fn.js +8 -0
  31. package/dist/tokens.fn.js.map +1 -0
  32. package/dist/types/decode-func.type.d.ts +1 -0
  33. package/dist/types/decode-func.type.js +3 -0
  34. package/dist/types/decode-func.type.js.map +1 -0
  35. package/dist/watch-kv.decorator.d.ts +23 -0
  36. package/dist/watch-kv.decorator.js +19 -0
  37. package/dist/watch-kv.decorator.js.map +1 -0
  38. package/dist/watch-kv.service.d.ts +37 -0
  39. package/dist/watch-kv.service.js +116 -0
  40. package/dist/watch-kv.service.js.map +1 -0
  41. package/jest.config.js +1 -0
  42. package/jest.config.unit.js +1 -0
  43. package/package.json +42 -0
  44. package/src/constants.ts +1 -0
  45. package/src/index.ts +5 -0
  46. package/src/inject-kv-service.decorator.ts +39 -0
  47. package/src/interfaces/nats-kv-entry-meta.interface.ts +6 -0
  48. package/src/interfaces/nats-kv-entry.interface.ts +8 -0
  49. package/src/kv-storage.ts +121 -0
  50. package/src/nats-kv-module.generator.ts +49 -0
  51. package/src/nats-kv.module.ts +58 -0
  52. package/src/nats-kv.service.ts +104 -0
  53. package/src/tokens.fn.ts +8 -0
  54. package/src/types/decode-func.type.ts +1 -0
  55. package/src/watch-kv.decorator.ts +30 -0
  56. package/src/watch-kv.service.ts +124 -0
  57. package/tsconfig.build.json +12 -0
  58. package/tsconfig.json +7 -0
package/CHANGELOG.md ADDED
@@ -0,0 +1,10 @@
1
+ # Change Log
2
+
3
+ All notable changes to this project will be documented in this file.
4
+ See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
+
6
+ ## [5.4.0-next.2](https://github.com/R-Vision/rsdk/compare/v5.4.0-next.1...v5.4.0-next.2) (2024-11-25)
7
+
8
+ ### Features
9
+
10
+ * **nats:** nats transport/kv/os + examples + docs ([#306](https://github.com/R-Vision/rsdk/issues/306)) ([de67eed](https://github.com/R-Vision/rsdk/commit/de67eed8b4cb17ec9d359067eae1e0c35d6cc736))
@@ -0,0 +1 @@
1
+ export declare const NATS_KV_STORAGES_RSDK_METADATA_SCOPE = "nats-kv-storages";
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NATS_KV_STORAGES_RSDK_METADATA_SCOPE = void 0;
4
+ exports.NATS_KV_STORAGES_RSDK_METADATA_SCOPE = 'nats-kv-storages';
5
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,oCAAoC,GAAG,kBAAkB,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { NatsKvService } from './nats-kv.service';
2
+ export { WatchKv, type KvWatcher } from './watch-kv.decorator';
3
+ export { NatsKvModule } from './nats-kv.module';
4
+ export * from './inject-kv-service.decorator';
5
+ export * from './kv-storage';
package/dist/index.js ADDED
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.NatsKvModule = exports.WatchKv = exports.NatsKvService = void 0;
18
+ var nats_kv_service_1 = require("./nats-kv.service");
19
+ Object.defineProperty(exports, "NatsKvService", { enumerable: true, get: function () { return nats_kv_service_1.NatsKvService; } });
20
+ var watch_kv_decorator_1 = require("./watch-kv.decorator");
21
+ Object.defineProperty(exports, "WatchKv", { enumerable: true, get: function () { return watch_kv_decorator_1.WatchKv; } });
22
+ var nats_kv_module_1 = require("./nats-kv.module");
23
+ Object.defineProperty(exports, "NatsKvModule", { enumerable: true, get: function () { return nats_kv_module_1.NatsKvModule; } });
24
+ __exportStar(require("./inject-kv-service.decorator"), exports);
25
+ __exportStar(require("./kv-storage"), exports);
26
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,qDAAkD;AAAzC,gHAAA,aAAa,OAAA;AACtB,2DAA+D;AAAtD,6GAAA,OAAO,OAAA;AAChB,mDAAgD;AAAvC,8GAAA,YAAY,OAAA;AACrB,gEAA8C;AAC9C,+CAA6B"}
@@ -0,0 +1,2 @@
1
+ export declare const InjectKvService: (connectionName?: string) => ParameterDecorator;
2
+ export declare const InjectNatsKv: (bucketName: string, connectionName?: string) => ParameterDecorator;
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InjectNatsKv = exports.InjectKvService = void 0;
4
+ const common_1 = require("@nestjs/common");
5
+ const metadata_1 = require("@rsdk/metadata");
6
+ const nats_kv_module_generator_1 = require("./nats-kv-module.generator");
7
+ const tokens_fn_1 = require("./tokens.fn");
8
+ const InjectKvService = (connectionName) => (0, common_1.Inject)((0, tokens_fn_1.createKvServiceToken)(connectionName));
9
+ exports.InjectKvService = InjectKvService;
10
+ const InjectNatsKv = (bucketName, connectionName) => {
11
+ return (target, propertyKey, parameterIndex) => {
12
+ (0, common_1.Inject)((0, tokens_fn_1.createKvToken)(bucketName, connectionName))(target, propertyKey, parameterIndex);
13
+ const key = `nats-kv:${bucketName}${connectionName ? `:${connectionName}` : ''}`;
14
+ const moduleDefinition = nats_kv_module_generator_1.NatsKvModuleGenerator.createClientModuleDefinition(target, bucketName, connectionName);
15
+ metadata_1.RsdkMetadata.setWithScope(target, metadata_1.PLATFORM_RAW_GLOBAL_METADATA_SCOPE, key, moduleDefinition, true);
16
+ };
17
+ };
18
+ exports.InjectNatsKv = InjectNatsKv;
19
+ //# sourceMappingURL=inject-kv-service.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inject-kv-service.decorator.js","sourceRoot":"","sources":["../src/inject-kv-service.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AACxC,6CAGwB;AAExB,yEAAmE;AACnE,2CAAkE;AAE3D,MAAM,eAAe,GAAG,CAAC,cAAuB,EAAsB,EAAE,CAC7E,IAAA,eAAM,EAAC,IAAA,gCAAoB,EAAC,cAAc,CAAC,CAAC,CAAC;AADlC,QAAA,eAAe,mBACmB;AAExC,MAAM,YAAY,GAAG,CAC1B,UAAkB,EAClB,cAAuB,EACH,EAAE;IACtB,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,cAAc,EAAE,EAAE;QAC7C,IAAA,eAAM,EAAC,IAAA,yBAAa,EAAC,UAAU,EAAE,cAAc,CAAC,CAAC,CAC/C,MAAM,EACN,WAAW,EACX,cAAc,CACf,CAAC;QAEF,MAAM,GAAG,GAAG,WAAW,UAAU,GAAG,cAAc,CAAC,CAAC,CAAC,IAAI,cAAc,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;QACjF,MAAM,gBAAgB,GAAG,gDAAqB,CAAC,4BAA4B,CACzE,MAAM,EACN,UAAU,EACV,cAAc,CACf,CAAC;QAEF,uBAAY,CAAC,YAAY,CACvB,MAAM,EACN,6CAAkC,EAClC,GAAG,EACH,gBAAgB,EAChB,IAAI,CACL,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC,CAAC;AA1BW,QAAA,YAAY,gBA0BvB"}
@@ -0,0 +1,6 @@
1
+ export interface NatsKvEntryMeta {
2
+ created: Date;
3
+ revision: number;
4
+ operation: 'PUT' | 'DEL' | 'PURGE';
5
+ length: number;
6
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=nats-kv-entry-meta.interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nats-kv-entry-meta.interface.js","sourceRoot":"","sources":["../../src/interfaces/nats-kv-entry-meta.interface.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ import type { DecodeFunc } from '../types/decode-func.type';
2
+ import type { NatsKvEntryMeta } from './nats-kv-entry-meta.interface';
3
+ export interface NatsKvEntry<Decode extends DecodeFunc> {
4
+ data: ReturnType<Decode>;
5
+ meta: NatsKvEntryMeta;
6
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=nats-kv-entry.interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nats-kv-entry.interface.js","sourceRoot":"","sources":["../../src/interfaces/nats-kv-entry.interface.ts"],"names":[],"mappings":""}
@@ -0,0 +1,23 @@
1
+ import type { ILogger } from '@rsdk/logging';
2
+ import type { KV, KvDeleteOptions, KvEntry, KvPutOptions, KvStatus, Payload } from 'nats';
3
+ import type { NatsKvEntry } from './interfaces/nats-kv-entry.interface';
4
+ import type { DecodeFunc } from './types/decode-func.type';
5
+ export declare class KvStorage {
6
+ private readonly storage;
7
+ private readonly logger;
8
+ constructor(storage: KV, logger: ILogger);
9
+ getKeys(filter?: string | string[]): Promise<string[]>;
10
+ getAllWithMeta<Decode extends DecodeFunc>(decode: Decode, filter?: string | string[]): Promise<NatsKvEntry<Decode>[]>;
11
+ get<Decode extends DecodeFunc>(key: string, decode: Decode): Promise<ReturnType<Decode> | null>;
12
+ getWithMeta(key: string): Promise<KvEntry | null>;
13
+ getAll<Decode extends DecodeFunc>(decode: Decode, filter?: string | string[]): Promise<ReturnType<Decode>[]>;
14
+ status(): Promise<KvStatus>;
15
+ put(key: string, data: Payload, opts?: Partial<KvPutOptions>): Promise<number>;
16
+ delete(key: string, opts?: Partial<KvDeleteOptions>): Promise<void>;
17
+ /**
18
+ * Возвращает сырой KV Nats. Используйте этот метод
19
+ * только в крайнем случае! Рекомендуется работать с оберткой
20
+ * для безопасного взаимодействия.
21
+ */
22
+ getRawStorage(): KV;
23
+ }
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.KvStorage = void 0;
4
+ class KvStorage {
5
+ storage;
6
+ logger;
7
+ constructor(storage, logger) {
8
+ this.storage = storage;
9
+ this.logger = logger;
10
+ }
11
+ async getKeys(filter) {
12
+ const keysIterator = await this.storage.keys(filter);
13
+ const keys = [];
14
+ for await (const key of keysIterator) {
15
+ keys.push(key);
16
+ }
17
+ return keys;
18
+ }
19
+ async getAllWithMeta(decode, filter) {
20
+ this.logger.trace('Getting all entries from KV', { filter });
21
+ /*
22
+ An additional array is used here, because kv.keys() returns an asynchronous iterator,
23
+ which bugs and stops sending new keys if you use kv.get() inside "for await of"
24
+ */
25
+ const keys = await this.getKeys(filter);
26
+ const result = [];
27
+ for (const key of keys) {
28
+ const entry = await this.storage.get(key);
29
+ if (!entry) {
30
+ this.logger.warn('KV entry not found', { key });
31
+ continue;
32
+ }
33
+ result.push({
34
+ data: decode(entry.value),
35
+ meta: {
36
+ created: entry.created,
37
+ length: entry.length,
38
+ operation: entry.operation,
39
+ revision: entry.revision,
40
+ },
41
+ });
42
+ }
43
+ this.logger.trace('Getting all entries from KV: KV entries received', {
44
+ count: result.length,
45
+ });
46
+ return result;
47
+ }
48
+ async get(key, decode) {
49
+ const entry = await this.getWithMeta(key);
50
+ if (!entry)
51
+ return null;
52
+ return decode(entry.value);
53
+ }
54
+ async getWithMeta(key) {
55
+ return this.storage.get(key);
56
+ }
57
+ async getAll(decode, filter) {
58
+ const entries = await this.getAllWithMeta(decode, filter);
59
+ return entries.map((entry) => entry.data);
60
+ }
61
+ async status() {
62
+ return this.storage.status();
63
+ }
64
+ async put(key, data, opts) {
65
+ return this.storage.put(key, data, opts);
66
+ }
67
+ async delete(key, opts) {
68
+ await this.storage.delete(key, opts);
69
+ }
70
+ /**
71
+ * Возвращает сырой KV Nats. Используйте этот метод
72
+ * только в крайнем случае! Рекомендуется работать с оберткой
73
+ * для безопасного взаимодействия.
74
+ */
75
+ getRawStorage() {
76
+ return this.storage;
77
+ }
78
+ }
79
+ exports.KvStorage = KvStorage;
80
+ //# sourceMappingURL=kv-storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kv-storage.js","sourceRoot":"","sources":["../src/kv-storage.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { DynamicModule } from '@nestjs/common';
2
+ export declare class NatsKvModuleGenerator {
3
+ static createClientModuleDefinition(target: object, bucketName: string, connectionName?: string): DynamicModule;
4
+ private static createClientProvider;
5
+ }
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NatsKvModuleGenerator = void 0;
4
+ const metadata_1 = require("@rsdk/metadata");
5
+ const constants_1 = require("./constants");
6
+ const nats_kv_module_1 = require("./nats-kv.module");
7
+ const tokens_fn_1 = require("./tokens.fn");
8
+ class NatsKvModuleGenerator {
9
+ static createClientModuleDefinition(target, bucketName, connectionName) {
10
+ const provider = NatsKvModuleGenerator.createClientProvider(bucketName, connectionName);
11
+ const moduleDefinition = {
12
+ global: true,
13
+ imports: [nats_kv_module_1.NatsKvModule.forFeature(connectionName)],
14
+ module: NatsKvModuleGenerator,
15
+ providers: [provider],
16
+ exports: [provider],
17
+ };
18
+ metadata_1.RsdkMetadata.add(target, { bucketName, connectionName }, constants_1.NATS_KV_STORAGES_RSDK_METADATA_SCOPE);
19
+ return moduleDefinition;
20
+ }
21
+ static createClientProvider(bucketName, connectionName) {
22
+ return {
23
+ provide: (0, tokens_fn_1.createKvToken)(bucketName, connectionName),
24
+ inject: [(0, tokens_fn_1.createKvServiceToken)(connectionName)],
25
+ useFactory: (service) => service.create({ bucketName, bindOnly: true }),
26
+ };
27
+ }
28
+ }
29
+ exports.NatsKvModuleGenerator = NatsKvModuleGenerator;
30
+ //# sourceMappingURL=nats-kv-module.generator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nats-kv-module.generator.js","sourceRoot":"","sources":["../src/nats-kv-module.generator.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAE9C,2CAAmE;AAEnE,qDAAgD;AAEhD,2CAAkE;AAElE,MAAa,qBAAqB;IAChC,MAAM,CAAC,4BAA4B,CACjC,MAAc,EACd,UAAkB,EAClB,cAAuB;QAEvB,MAAM,QAAQ,GAAG,qBAAqB,CAAC,oBAAoB,CACzD,UAAU,EACV,cAAc,CACf,CAAC;QAEF,MAAM,gBAAgB,GAAkB;YACtC,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE,CAAC,6BAAY,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;YAClD,MAAM,EAAE,qBAAqB;YAC7B,SAAS,EAAE,CAAC,QAAQ,CAAC;YACrB,OAAO,EAAE,CAAC,QAAQ,CAAC;SACpB,CAAC;QAEF,uBAAY,CAAC,GAAG,CACd,MAAM,EACN,EAAE,UAAU,EAAE,cAAc,EAAE,EAC9B,gDAAoC,CACrC,CAAC;QAEF,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAEO,MAAM,CAAC,oBAAoB,CACjC,UAAkB,EAClB,cAAuB;QAEvB,OAAO;YACL,OAAO,EAAE,IAAA,yBAAa,EAAC,UAAU,EAAE,cAAc,CAAC;YAClD,MAAM,EAAE,CAAC,IAAA,gCAAoB,EAAC,cAAc,CAAC,CAAC;YAC9C,UAAU,EAAE,CAAC,OAAsB,EAAsB,EAAE,CACzD,OAAO,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;SACjD,CAAC;IACJ,CAAC;CACF;AAvCD,sDAuCC"}
@@ -0,0 +1,9 @@
1
+ import type { DynamicModule, OnModuleDestroy, OnModuleInit } from '@nestjs/common';
2
+ import { WatchKvService } from './watch-kv.service';
3
+ export declare class NatsKvModule implements OnModuleInit, OnModuleDestroy {
4
+ private readonly watchKvService;
5
+ constructor(watchKvService: WatchKvService);
6
+ static forFeature(connectionName?: string): DynamicModule;
7
+ onModuleInit(): Promise<void>;
8
+ onModuleDestroy(): Promise<void>;
9
+ }
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var NatsKvModule_1;
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.NatsKvModule = void 0;
14
+ const common_1 = require("@nestjs/common");
15
+ const core_1 = require("@nestjs/core");
16
+ const nats_common_1 = require("@rsdk/nats.common");
17
+ const nats_kv_service_1 = require("./nats-kv.service");
18
+ const tokens_fn_1 = require("./tokens.fn");
19
+ const watch_kv_service_1 = require("./watch-kv.service");
20
+ let NatsKvModule = NatsKvModule_1 = class NatsKvModule {
21
+ watchKvService;
22
+ constructor(watchKvService) {
23
+ this.watchKvService = watchKvService;
24
+ }
25
+ static forFeature(connectionName) {
26
+ const clientProvider = {
27
+ provide: (0, tokens_fn_1.createKvServiceToken)(connectionName),
28
+ useClass: nats_kv_service_1.NatsKvService,
29
+ };
30
+ return {
31
+ module: NatsKvModule_1,
32
+ providers: [
33
+ {
34
+ provide: nats_common_1.NATS_CLIENT_INJECTION_TOKEN_FOR_PACKAGE,
35
+ useExisting: connectionName
36
+ ? (0, nats_common_1.createNatsClientToken)(connectionName)
37
+ : nats_common_1.NATS_CLIENT_INJECTION_TOKEN,
38
+ },
39
+ {
40
+ provide: 'CONNECTION_NAME',
41
+ useFactory: () => connectionName,
42
+ },
43
+ clientProvider,
44
+ ],
45
+ exports: [clientProvider],
46
+ };
47
+ }
48
+ async onModuleInit() {
49
+ await this.watchKvService?.runWatches();
50
+ }
51
+ async onModuleDestroy() {
52
+ await this.watchKvService?.stopWatches();
53
+ }
54
+ };
55
+ exports.NatsKvModule = NatsKvModule;
56
+ exports.NatsKvModule = NatsKvModule = NatsKvModule_1 = __decorate([
57
+ (0, common_1.Module)({
58
+ imports: [core_1.DiscoveryModule],
59
+ providers: [nats_kv_service_1.NatsKvService, watch_kv_service_1.WatchKvService],
60
+ }),
61
+ __metadata("design:paramtypes", [watch_kv_service_1.WatchKvService])
62
+ ], NatsKvModule);
63
+ //# sourceMappingURL=nats-kv.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nats-kv.module.js","sourceRoot":"","sources":["../src/nats-kv.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAMA,2CAAwC;AACxC,uCAA+C;AAC/C,mDAI2B;AAE3B,uDAAkD;AAClD,2CAAmD;AACnD,yDAAoD;AAM7C,IAAM,YAAY,oBAAlB,MAAM,YAAY;IACM;IAA7B,YAA6B,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;IAAG,CAAC;IAExD,MAAM,CAAC,UAAU,CAAC,cAAuB;QAC9C,MAAM,cAAc,GAAa;YAC/B,OAAO,EAAE,IAAA,gCAAoB,EAAC,cAAc,CAAC;YAC7C,QAAQ,EAAE,+BAAa;SACxB,CAAC;QAEF,OAAO;YACL,MAAM,EAAE,cAAY;YACpB,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,qDAAuC;oBAChD,WAAW,EAAE,cAAc;wBACzB,CAAC,CAAC,IAAA,mCAAqB,EAAC,cAAc,CAAC;wBACvC,CAAC,CAAC,yCAA2B;iBAChC;gBACD;oBACE,OAAO,EAAE,iBAAiB;oBAC1B,UAAU,EAAE,GAAG,EAAE,CAAC,cAAc;iBACjC;gBACD,cAAc;aACf;YACD,OAAO,EAAE,CAAC,cAAc,CAAC;SAC1B,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,MAAM,IAAI,CAAC,cAAc,EAAE,UAAU,EAAE,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,eAAe;QACnB,MAAM,IAAI,CAAC,cAAc,EAAE,WAAW,EAAE,CAAC;IAC3C,CAAC;CACF,CAAA;AAnCY,oCAAY;uBAAZ,YAAY;IAJxB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,sBAAe,CAAC;QAC1B,SAAS,EAAE,CAAC,+BAAa,EAAE,iCAAc,CAAC;KAC3C,CAAC;qCAE6C,iCAAc;GADhD,YAAY,CAmCxB"}
@@ -0,0 +1,31 @@
1
+ import { ILogger } from '@rsdk/logging';
2
+ import { NatsConnection } from 'nats';
3
+ import type { KvOptions } from 'nats/lib/jetstream/types';
4
+ import { KvStorage } from './kv-storage';
5
+ export declare class NatsKvService {
6
+ private readonly logger;
7
+ private readonly nats;
8
+ constructor(logger: ILogger, nats: NatsConnection);
9
+ /**
10
+ * Gets or creates a JetStream KV store
11
+ */
12
+ create({ bucketName, domain, ...opts }: Partial<KvOptions> & {
13
+ bucketName: string;
14
+ domain?: string;
15
+ }): Promise<KvStorage>;
16
+ /**
17
+ * Waits for the specified bucket to exist.
18
+ *
19
+ * @param bucketName - The name of the bucket to wait for.
20
+ * @param timeout - The maximum time to wait for the bucket to exist, in milliseconds. Defaults to infinity.
21
+ * @throws {InternalException} If the bucket does not exist within the specified timeout.
22
+ */
23
+ waitForBucketExists(bucketName: string, timeout?: number): Promise<void>;
24
+ /**
25
+ * Checks if a bucket exists.
26
+ *
27
+ * @param bucket - The name of the bucket to check.
28
+ * @returns A promise that resolves to a boolean indicating whether the bucket exists or not.
29
+ */
30
+ isBucketExists(bucketName: string): Promise<boolean>;
31
+ }
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.NatsKvService = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const common_2 = require("@rsdk/common");
18
+ const core_1 = require("@rsdk/core");
19
+ const nats_common_1 = require("@rsdk/nats.common");
20
+ const kv_storage_1 = require("./kv-storage");
21
+ let NatsKvService = class NatsKvService {
22
+ logger;
23
+ nats;
24
+ constructor(logger, nats) {
25
+ this.logger = logger;
26
+ this.nats = nats;
27
+ }
28
+ /**
29
+ * Gets or creates a JetStream KV store
30
+ */
31
+ async create({ bucketName, domain, ...opts }) {
32
+ const jsOptions = domain ? { domain } : undefined;
33
+ try {
34
+ const kv = await this.nats
35
+ .jetstream(jsOptions)
36
+ .views.kv(bucketName, opts);
37
+ if (opts.bindOnly && !(await kv.status())) {
38
+ throw new common_1.NotFoundException(`Nats KV ${bucketName} not found`);
39
+ }
40
+ this.logger.trace('KV store initialized', {
41
+ connectionName: this.nats.info,
42
+ bucketName,
43
+ });
44
+ return new kv_storage_1.KvStorage(kv, this.logger);
45
+ }
46
+ catch (error) {
47
+ this.logger.error('Failed to get or create KV store', {
48
+ err: error,
49
+ bucketName,
50
+ });
51
+ throw error;
52
+ }
53
+ }
54
+ /**
55
+ * Waits for the specified bucket to exist.
56
+ *
57
+ * @param bucketName - The name of the bucket to wait for.
58
+ * @param timeout - The maximum time to wait for the bucket to exist, in milliseconds. Defaults to infinity.
59
+ * @throws {InternalException} If the bucket does not exist within the specified timeout.
60
+ */
61
+ async waitForBucketExists(bucketName, timeout = Number.POSITIVE_INFINITY) {
62
+ const start = Date.now();
63
+ while (true) {
64
+ if (await this.isBucketExists(bucketName)) {
65
+ this.logger.trace('KV bucket exists');
66
+ return;
67
+ }
68
+ if (timeout && Date.now() - start > timeout) {
69
+ throw new core_1.InternalException(`Bucket ${bucketName} does not exist`);
70
+ }
71
+ this.logger.trace('KV bucket does not exist, retry after 3 seconds...', {
72
+ bucketName,
73
+ });
74
+ await (0, common_2.delay)(common_2.Timespan.second(3));
75
+ }
76
+ }
77
+ /**
78
+ * Checks if a bucket exists.
79
+ *
80
+ * @param bucket - The name of the bucket to check.
81
+ * @returns A promise that resolves to a boolean indicating whether the bucket exists or not.
82
+ */
83
+ async isBucketExists(bucketName) {
84
+ try {
85
+ const kv = await this.create({ bucketName, bindOnly: true });
86
+ await kv.status();
87
+ }
88
+ catch {
89
+ return false;
90
+ }
91
+ return true;
92
+ }
93
+ };
94
+ exports.NatsKvService = NatsKvService;
95
+ exports.NatsKvService = NatsKvService = __decorate([
96
+ (0, common_1.Injectable)(),
97
+ __param(0, (0, core_1.InjectLogger)(NatsKvService)),
98
+ __param(1, (0, common_1.Inject)(nats_common_1.NATS_CLIENT_INJECTION_TOKEN_FOR_PACKAGE)),
99
+ __metadata("design:paramtypes", [Object, Object])
100
+ ], NatsKvService);
101
+ //# sourceMappingURL=nats-kv.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nats-kv.service.js","sourceRoot":"","sources":["../src/nats-kv.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare const createKvServiceToken: (connectionName?: string) => string;
2
+ export declare const createKvToken: (bucketName: string, connectionName?: string) => string;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createKvToken = exports.createKvServiceToken = void 0;
4
+ const createKvServiceToken = (connectionName) => `NATS_KV_SERVICE${connectionName ? `_${connectionName}` : ''}`;
5
+ exports.createKvServiceToken = createKvServiceToken;
6
+ const createKvToken = (bucketName, connectionName) => `NATS_KV_${bucketName}${connectionName ? `_${connectionName}` : ''}`;
7
+ exports.createKvToken = createKvToken;
8
+ //# sourceMappingURL=tokens.fn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tokens.fn.js","sourceRoot":"","sources":["../src/tokens.fn.ts"],"names":[],"mappings":";;;AAAO,MAAM,oBAAoB,GAAG,CAAC,cAAuB,EAAU,EAAE,CACtE,kBAAkB,cAAc,CAAC,CAAC,CAAC,IAAI,cAAc,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;AADpD,QAAA,oBAAoB,wBACgC;AAE1D,MAAM,aAAa,GAAG,CAC3B,UAAkB,EAClB,cAAuB,EACf,EAAE,CACV,WAAW,UAAU,GAAG,cAAc,CAAC,CAAC,CAAC,IAAI,cAAc,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;AAJ1D,QAAA,aAAa,iBAI6C"}
@@ -0,0 +1 @@
1
+ export type DecodeFunc = (value: Uint8Array) => any;
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=decode-func.type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decode-func.type.js","sourceRoot":"","sources":["../../src/types/decode-func.type.ts"],"names":[],"mappings":""}
@@ -0,0 +1,23 @@
1
+ import type { KvEntry } from 'nats';
2
+ export type WatchConfig = {
3
+ bucket: string;
4
+ filter?: string;
5
+ connectionName?: string;
6
+ };
7
+ export interface KvWatcher {
8
+ onDelete(entry: KvEntry): Promise<void>;
9
+ onPurge(entry: KvEntry): Promise<void>;
10
+ onPut(entry: KvEntry): Promise<void>;
11
+ }
12
+ /**
13
+ * Key used to mark class as a watcher for key-value pairs.
14
+ */
15
+ export declare const WATCH_NATS_KV_KEY = "WATCH_NATS_KV";
16
+ /**
17
+ * Decorator used to mark class as a watcher for key-value pairs.
18
+ * Needs to be used in conjunction with the `KvWatcher` interface.
19
+ *
20
+ * @param {WatchConfig} config - The configuration for watching key-value pairs.
21
+ * @returns {void}
22
+ */
23
+ export declare const WatchKv: import("@nestjs/core").ReflectableDecorator<WatchConfig, WatchConfig>;
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WatchKv = exports.WATCH_NATS_KV_KEY = void 0;
4
+ const core_1 = require("@nestjs/core");
5
+ /**
6
+ * Key used to mark class as a watcher for key-value pairs.
7
+ */
8
+ exports.WATCH_NATS_KV_KEY = 'WATCH_NATS_KV';
9
+ /**
10
+ * Decorator used to mark class as a watcher for key-value pairs.
11
+ * Needs to be used in conjunction with the `KvWatcher` interface.
12
+ *
13
+ * @param {WatchConfig} config - The configuration for watching key-value pairs.
14
+ * @returns {void}
15
+ */
16
+ exports.WatchKv = core_1.Reflector.createDecorator({
17
+ key: exports.WATCH_NATS_KV_KEY,
18
+ });
19
+ //# sourceMappingURL=watch-kv.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"watch-kv.decorator.js","sourceRoot":"","sources":["../src/watch-kv.decorator.ts"],"names":[],"mappings":";;;AAAA,uCAAyC;AAezC;;GAEG;AACU,QAAA,iBAAiB,GAAG,eAAe,CAAC;AAEjD;;;;;;GAMG;AACU,QAAA,OAAO,GAAG,gBAAS,CAAC,eAAe,CAAc;IAC5D,GAAG,EAAE,yBAAiB;CACvB,CAAC,CAAC"}
@@ -0,0 +1,37 @@
1
+ import { DiscoveryService } from '@nestjs/core';
2
+ import { ILogger } from '@rsdk/logging';
3
+ import type { KV, KvEntry, KvWatchOptions } from 'nats';
4
+ import { NatsKvService } from './nats-kv.service';
5
+ export declare class WatchKvService {
6
+ private readonly logger;
7
+ private readonly discovery;
8
+ private readonly nats;
9
+ private readonly connectionName?;
10
+ constructor(logger: ILogger, discovery: DiscoveryService, nats: NatsKvService, connectionName?: string | undefined);
11
+ /**
12
+ * Runs the watches for the key-value service.
13
+ * Waits for buckets to exist and starts the watch operation for each bucket.
14
+ */
15
+ runWatches(): Promise<void>;
16
+ /**
17
+ * Stops all watches.
18
+ *
19
+ * @note This method is not implemented yet.
20
+ */
21
+ stopWatches(): Promise<void>;
22
+ watch(kv: KV, opts: KvWatchOptions, callback: (event: KvEntry) => Promise<void>): Promise<void>;
23
+ /**
24
+ * Runs the watch operation for the given metadata and watcher.
25
+ *
26
+ * @param config - The watch configuration.
27
+ * @param watcher - The KvWatcher instance.
28
+ * @returns A Promise that resolves when the watch operation is complete.
29
+ */
30
+ private runWatch;
31
+ /**
32
+ * Discovers and returns an array of KvWatcher instances along with their corresponding metadata.
33
+ *
34
+ * @returns An array of objects containing the KvWatcher instance and its metadata.
35
+ */
36
+ private discoverWatchers;
37
+ }