@loipv/nestjs-kafka 0.0.1

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 (69) hide show
  1. package/README.md +377 -0
  2. package/dist/consumer.module.d.ts +10 -0
  3. package/dist/consumer.module.js +38 -0
  4. package/dist/consumer.module.js.map +1 -0
  5. package/dist/decorators/constants.d.ts +1 -0
  6. package/dist/decorators/constants.js +5 -0
  7. package/dist/decorators/constants.js.map +1 -0
  8. package/dist/decorators/consumer.decorator.d.ts +8 -0
  9. package/dist/decorators/consumer.decorator.js +16 -0
  10. package/dist/decorators/consumer.decorator.js.map +1 -0
  11. package/dist/decorators/index.d.ts +2 -0
  12. package/dist/decorators/index.js +21 -0
  13. package/dist/decorators/index.js.map +1 -0
  14. package/dist/discovery/consumer-discovery.service.d.ts +14 -0
  15. package/dist/discovery/consumer-discovery.service.js +82 -0
  16. package/dist/discovery/consumer-discovery.service.js.map +1 -0
  17. package/dist/discovery/index.d.ts +1 -0
  18. package/dist/discovery/index.js +18 -0
  19. package/dist/discovery/index.js.map +1 -0
  20. package/dist/health/index.d.ts +1 -0
  21. package/dist/health/index.js +18 -0
  22. package/dist/health/index.js.map +1 -0
  23. package/dist/health/kafka-health-indicator.d.ts +12 -0
  24. package/dist/health/kafka-health-indicator.js +98 -0
  25. package/dist/health/kafka-health-indicator.js.map +1 -0
  26. package/dist/index.d.ts +6 -0
  27. package/dist/index.js +29 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/interfaces/consumer-options.interface.d.ts +52 -0
  30. package/dist/interfaces/consumer-options.interface.js +3 -0
  31. package/dist/interfaces/consumer-options.interface.js.map +1 -0
  32. package/dist/interfaces/index.d.ts +3 -0
  33. package/dist/interfaces/index.js +20 -0
  34. package/dist/interfaces/index.js.map +1 -0
  35. package/dist/interfaces/kafka-module-options.interface.d.ts +43 -0
  36. package/dist/interfaces/kafka-module-options.interface.js +5 -0
  37. package/dist/interfaces/kafka-module-options.interface.js.map +1 -0
  38. package/dist/interfaces/message.interface.d.ts +26 -0
  39. package/dist/interfaces/message.interface.js +3 -0
  40. package/dist/interfaces/message.interface.js.map +1 -0
  41. package/dist/kafka.module.d.ts +7 -0
  42. package/dist/kafka.module.js +97 -0
  43. package/dist/kafka.module.js.map +1 -0
  44. package/dist/services/batch-processor.service.d.ts +16 -0
  45. package/dist/services/batch-processor.service.js +102 -0
  46. package/dist/services/batch-processor.service.js.map +1 -0
  47. package/dist/services/consumer-registry.service.d.ts +27 -0
  48. package/dist/services/consumer-registry.service.js +195 -0
  49. package/dist/services/consumer-registry.service.js.map +1 -0
  50. package/dist/services/dlq.service.d.ts +14 -0
  51. package/dist/services/dlq.service.js +90 -0
  52. package/dist/services/dlq.service.js.map +1 -0
  53. package/dist/services/idempotency.service.d.ts +16 -0
  54. package/dist/services/idempotency.service.js +76 -0
  55. package/dist/services/idempotency.service.js.map +1 -0
  56. package/dist/services/index.d.ts +7 -0
  57. package/dist/services/index.js +24 -0
  58. package/dist/services/index.js.map +1 -0
  59. package/dist/services/kafka-client.service.d.ts +31 -0
  60. package/dist/services/kafka-client.service.js +183 -0
  61. package/dist/services/kafka-client.service.js.map +1 -0
  62. package/dist/services/kafka-core.service.d.ts +13 -0
  63. package/dist/services/kafka-core.service.js +87 -0
  64. package/dist/services/kafka-core.service.js.map +1 -0
  65. package/dist/services/pressure-manager.service.d.ts +14 -0
  66. package/dist/services/pressure-manager.service.js +75 -0
  67. package/dist/services/pressure-manager.service.js.map +1 -0
  68. package/dist/tsconfig.build.tsbuildinfo +1 -0
  69. package/package.json +95 -0
@@ -0,0 +1,195 @@
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 ConsumerRegistryService_1;
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.ConsumerRegistryService = void 0;
14
+ const common_1 = require("@nestjs/common");
15
+ const kafka_core_service_1 = require("./kafka-core.service");
16
+ const batch_processor_service_1 = require("./batch-processor.service");
17
+ const idempotency_service_1 = require("./idempotency.service");
18
+ const pressure_manager_service_1 = require("./pressure-manager.service");
19
+ const dlq_service_1 = require("./dlq.service");
20
+ let ConsumerRegistryService = ConsumerRegistryService_1 = class ConsumerRegistryService {
21
+ kafkaCore;
22
+ batchProcessor;
23
+ idempotencyService;
24
+ pressureManager;
25
+ dlqService;
26
+ logger = new common_1.Logger(ConsumerRegistryService_1.name);
27
+ registeredConsumers = new Map();
28
+ isShuttingDown = false;
29
+ constructor(kafkaCore, batchProcessor, idempotencyService, pressureManager, dlqService) {
30
+ this.kafkaCore = kafkaCore;
31
+ this.batchProcessor = batchProcessor;
32
+ this.idempotencyService = idempotencyService;
33
+ this.pressureManager = pressureManager;
34
+ this.dlqService = dlqService;
35
+ }
36
+ registerConsumers(consumers) {
37
+ for (const metadata of consumers) {
38
+ this.registerConsumer(metadata);
39
+ }
40
+ }
41
+ registerConsumer(metadata) {
42
+ const { topic, options } = metadata;
43
+ const consumerId = `${topic}-${options.groupId || 'default'}`;
44
+ const consumer = this.kafkaCore.getKafka().consumer({
45
+ groupId: options.groupId || `${topic}-group`,
46
+ sessionTimeout: options.sessionTimeout,
47
+ heartbeatInterval: options.heartbeatInterval,
48
+ rebalanceTimeout: options.rebalanceTimeout,
49
+ maxBytesPerPartition: 1048576,
50
+ });
51
+ this.pressureManager.register(consumerId, consumer, {
52
+ backPressureThreshold: options.backPressureThreshold || 80,
53
+ resumeThreshold: 60,
54
+ maxQueueSize: options.maxQueueSize || 1000,
55
+ checkIntervalMs: 1000,
56
+ });
57
+ this.registeredConsumers.set(consumerId, {
58
+ metadata,
59
+ consumer,
60
+ isRunning: false,
61
+ });
62
+ this.logger.log(`Registered consumer: ${consumerId}`);
63
+ }
64
+ async startAll() {
65
+ const startPromises = Array.from(this.registeredConsumers.values()).map((registered) => this.startConsumer(registered));
66
+ await Promise.all(startPromises);
67
+ }
68
+ async startConsumer(registered) {
69
+ const { metadata, consumer } = registered;
70
+ const { topic, options } = metadata;
71
+ try {
72
+ await consumer.connect();
73
+ await consumer.subscribe({
74
+ topic,
75
+ fromBeginning: options.fromBeginning,
76
+ });
77
+ if (options.batch) {
78
+ await this.startBatchConsumer(registered);
79
+ }
80
+ else {
81
+ await this.startMessageConsumer(registered);
82
+ }
83
+ registered.isRunning = true;
84
+ this.logger.log(`Started consumer for topic: ${topic}`);
85
+ }
86
+ catch (error) {
87
+ this.logger.error(`Failed to start consumer for topic: ${topic}`, error);
88
+ throw error;
89
+ }
90
+ }
91
+ async startMessageConsumer(registered) {
92
+ const { metadata, consumer } = registered;
93
+ const { topic, options, target, methodName } = metadata;
94
+ const handler = target[methodName].bind(target);
95
+ await consumer.run({
96
+ autoCommit: options.autoCommit !== false,
97
+ autoCommitInterval: options.autoCommitInterval,
98
+ autoCommitThreshold: options.autoCommitThreshold,
99
+ eachMessage: async (payload) => {
100
+ if (this.isShuttingDown)
101
+ return;
102
+ const { message, partition } = payload;
103
+ if (options.idempotencyKey) {
104
+ if (this.idempotencyService.isProcessed(message, options.idempotencyKey)) {
105
+ this.logger.debug('Skipping duplicate message');
106
+ return;
107
+ }
108
+ }
109
+ try {
110
+ await handler(message);
111
+ if (options.idempotencyKey) {
112
+ this.idempotencyService.markProcessed(message, options.idempotencyKey);
113
+ }
114
+ this.dlqService.clearRetryState(message, topic, partition);
115
+ }
116
+ catch (error) {
117
+ await this.handleError(message, error, metadata, partition);
118
+ }
119
+ },
120
+ });
121
+ }
122
+ async startBatchConsumer(registered) {
123
+ const { metadata, consumer } = registered;
124
+ const { options, target, methodName } = metadata;
125
+ const handler = target[methodName].bind(target);
126
+ const eachBatchHandler = this.batchProcessor.createEachBatchHandler(options, async (messages) => {
127
+ if (this.isShuttingDown)
128
+ return;
129
+ let processableMessages = messages;
130
+ if (options.idempotencyKey) {
131
+ processableMessages = this.idempotencyService.filterDuplicates(messages, options.idempotencyKey);
132
+ }
133
+ if (options.groupByKey) {
134
+ const grouped = this.batchProcessor.groupMessagesByKey(processableMessages);
135
+ await handler(grouped);
136
+ }
137
+ else {
138
+ await handler(processableMessages);
139
+ }
140
+ if (options.idempotencyKey) {
141
+ for (const msg of processableMessages) {
142
+ this.idempotencyService.markProcessed(msg, options.idempotencyKey);
143
+ }
144
+ }
145
+ });
146
+ await consumer.run({
147
+ autoCommit: false,
148
+ eachBatch: eachBatchHandler,
149
+ });
150
+ }
151
+ async handleError(message, error, metadata, partition) {
152
+ const { topic, options } = metadata;
153
+ this.logger.error(`Error processing message from ${topic}`, error);
154
+ if (options.dlq) {
155
+ const shouldRetry = await this.dlqService.handleFailure(message, error, options.dlq, topic, partition);
156
+ if (shouldRetry) {
157
+ throw error;
158
+ }
159
+ }
160
+ else {
161
+ throw error;
162
+ }
163
+ }
164
+ async gracefulShutdown() {
165
+ this.isShuttingDown = true;
166
+ this.logger.log('Starting graceful shutdown of consumers...');
167
+ const shutdownPromises = Array.from(this.registeredConsumers.values()).map(async (registered) => {
168
+ try {
169
+ if (registered.isRunning) {
170
+ await registered.consumer.stop();
171
+ await registered.consumer.disconnect();
172
+ }
173
+ }
174
+ catch (error) {
175
+ this.logger.error('Error during consumer shutdown', error);
176
+ }
177
+ });
178
+ await Promise.all(shutdownPromises);
179
+ this.idempotencyService.stopCleanup();
180
+ this.logger.log('All consumers shut down gracefully');
181
+ }
182
+ async onApplicationShutdown() {
183
+ await this.gracefulShutdown();
184
+ }
185
+ };
186
+ exports.ConsumerRegistryService = ConsumerRegistryService;
187
+ exports.ConsumerRegistryService = ConsumerRegistryService = ConsumerRegistryService_1 = __decorate([
188
+ (0, common_1.Injectable)(),
189
+ __metadata("design:paramtypes", [kafka_core_service_1.KafkaCoreService,
190
+ batch_processor_service_1.BatchProcessorService,
191
+ idempotency_service_1.IdempotencyService,
192
+ pressure_manager_service_1.PressureManagerService,
193
+ dlq_service_1.DlqService])
194
+ ], ConsumerRegistryService);
195
+ //# sourceMappingURL=consumer-registry.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consumer-registry.service.js","sourceRoot":"","sources":["../../lib/services/consumer-registry.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { KafkaMessage } from 'kafkajs';
2
+ import { KafkaClient } from './kafka-client.service';
3
+ import { DlqOptions } from '../interfaces';
4
+ export declare class DlqService {
5
+ private readonly kafkaClient;
6
+ private readonly logger;
7
+ private retryStates;
8
+ constructor(kafkaClient: KafkaClient);
9
+ handleFailure(message: KafkaMessage, error: Error, options: DlqOptions, originalTopic: string, partition?: number): Promise<boolean>;
10
+ private sendToDlq;
11
+ private getMessageKey;
12
+ private sleep;
13
+ clearRetryState(message: KafkaMessage, topic: string, partition?: number): void;
14
+ }
@@ -0,0 +1,90 @@
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
+ var DlqService_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.DlqService = void 0;
17
+ const common_1 = require("@nestjs/common");
18
+ const kafka_client_service_1 = require("./kafka-client.service");
19
+ let DlqService = DlqService_1 = class DlqService {
20
+ kafkaClient;
21
+ logger = new common_1.Logger(DlqService_1.name);
22
+ retryStates = new Map();
23
+ constructor(kafkaClient) {
24
+ this.kafkaClient = kafkaClient;
25
+ }
26
+ async handleFailure(message, error, options, originalTopic, partition) {
27
+ const messageKey = this.getMessageKey(message, originalTopic, partition);
28
+ let state = this.retryStates.get(messageKey);
29
+ if (!state) {
30
+ state = { retryCount: 0 };
31
+ this.retryStates.set(messageKey, state);
32
+ }
33
+ state.retryCount++;
34
+ state.lastError = error;
35
+ const maxRetries = options.maxRetries ?? 3;
36
+ if (state.retryCount <= maxRetries) {
37
+ const baseDelay = options.retryDelay ?? 1000;
38
+ const multiplier = options.retryBackoffMultiplier ?? 2;
39
+ const delay = baseDelay * Math.pow(multiplier, state.retryCount - 1);
40
+ this.logger.warn(`Retry ${state.retryCount}/${maxRetries} for message, waiting ${delay}ms`);
41
+ await this.sleep(delay);
42
+ return true;
43
+ }
44
+ await this.sendToDlq(message, error, options, originalTopic, state.retryCount);
45
+ this.retryStates.delete(messageKey);
46
+ return false;
47
+ }
48
+ async sendToDlq(message, error, options, originalTopic, retryCount) {
49
+ const headers = {};
50
+ if (options.includeOriginalHeaders !== false && message.headers) {
51
+ Object.assign(headers, message.headers);
52
+ }
53
+ headers['x-dlq-original-topic'] = originalTopic;
54
+ headers['x-dlq-retry-count'] = String(retryCount);
55
+ headers['x-dlq-timestamp'] = new Date().toISOString();
56
+ if (options.includeErrorInfo !== false) {
57
+ headers['x-dlq-error-message'] = error.message;
58
+ headers['x-dlq-error-stack'] = error.stack || '';
59
+ }
60
+ try {
61
+ await this.kafkaClient.send(options.topic, {
62
+ key: message.key,
63
+ value: message.value,
64
+ headers,
65
+ });
66
+ this.logger.warn(`Message sent to DLQ: ${options.topic} after ${retryCount} retries`);
67
+ }
68
+ catch (dlqError) {
69
+ this.logger.error('Failed to send message to DLQ', dlqError);
70
+ throw dlqError;
71
+ }
72
+ }
73
+ getMessageKey(message, topic, partition) {
74
+ return `${topic}:${partition ?? 0}:${message.offset}`;
75
+ }
76
+ sleep(ms) {
77
+ return new Promise((resolve) => setTimeout(resolve, ms));
78
+ }
79
+ clearRetryState(message, topic, partition) {
80
+ const key = this.getMessageKey(message, topic, partition);
81
+ this.retryStates.delete(key);
82
+ }
83
+ };
84
+ exports.DlqService = DlqService;
85
+ exports.DlqService = DlqService = DlqService_1 = __decorate([
86
+ (0, common_1.Injectable)(),
87
+ __param(0, (0, common_1.Inject)((0, common_1.forwardRef)(() => kafka_client_service_1.KafkaClient))),
88
+ __metadata("design:paramtypes", [kafka_client_service_1.KafkaClient])
89
+ ], DlqService);
90
+ //# sourceMappingURL=dlq.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dlq.service.js","sourceRoot":"","sources":["../../lib/services/dlq.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { OnModuleDestroy } from '@nestjs/common';
2
+ import { KafkaMessage } from 'kafkajs';
3
+ export declare class IdempotencyService implements OnModuleDestroy {
4
+ private readonly logger;
5
+ private processedKeys;
6
+ private cleanupInterval;
7
+ private readonly defaultTtl;
8
+ constructor();
9
+ onModuleDestroy(): void;
10
+ isProcessed(message: KafkaMessage, keyExtractor?: (msg: KafkaMessage) => string | undefined): boolean;
11
+ markProcessed(message: KafkaMessage, keyExtractor?: (msg: KafkaMessage) => string | undefined): void;
12
+ filterDuplicates(messages: KafkaMessage[], keyExtractor?: (msg: KafkaMessage) => string | undefined): KafkaMessage[];
13
+ private extractKey;
14
+ private startCleanup;
15
+ stopCleanup(): void;
16
+ }
@@ -0,0 +1,76 @@
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 IdempotencyService_1;
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.IdempotencyService = void 0;
14
+ const common_1 = require("@nestjs/common");
15
+ let IdempotencyService = IdempotencyService_1 = class IdempotencyService {
16
+ logger = new common_1.Logger(IdempotencyService_1.name);
17
+ processedKeys = new Map();
18
+ cleanupInterval = null;
19
+ defaultTtl = 3600000;
20
+ constructor() {
21
+ this.startCleanup();
22
+ }
23
+ onModuleDestroy() {
24
+ this.stopCleanup();
25
+ }
26
+ isProcessed(message, keyExtractor) {
27
+ const key = this.extractKey(message, keyExtractor);
28
+ if (!key)
29
+ return false;
30
+ return this.processedKeys.has(key);
31
+ }
32
+ markProcessed(message, keyExtractor) {
33
+ const key = this.extractKey(message, keyExtractor);
34
+ if (!key)
35
+ return;
36
+ this.processedKeys.set(key, {
37
+ key,
38
+ timestamp: Date.now(),
39
+ });
40
+ }
41
+ filterDuplicates(messages, keyExtractor) {
42
+ return messages.filter((msg) => !this.isProcessed(msg, keyExtractor));
43
+ }
44
+ extractKey(message, keyExtractor) {
45
+ if (keyExtractor) {
46
+ return keyExtractor(message);
47
+ }
48
+ const header = message.headers?.['idempotency-key'];
49
+ if (header) {
50
+ return Buffer.isBuffer(header) ? header.toString() : String(header);
51
+ }
52
+ return undefined;
53
+ }
54
+ startCleanup() {
55
+ this.cleanupInterval = setInterval(() => {
56
+ const now = Date.now();
57
+ for (const [key, entry] of this.processedKeys.entries()) {
58
+ if (now - entry.timestamp > this.defaultTtl) {
59
+ this.processedKeys.delete(key);
60
+ }
61
+ }
62
+ }, 60000);
63
+ }
64
+ stopCleanup() {
65
+ if (this.cleanupInterval) {
66
+ clearInterval(this.cleanupInterval);
67
+ this.cleanupInterval = null;
68
+ }
69
+ }
70
+ };
71
+ exports.IdempotencyService = IdempotencyService;
72
+ exports.IdempotencyService = IdempotencyService = IdempotencyService_1 = __decorate([
73
+ (0, common_1.Injectable)(),
74
+ __metadata("design:paramtypes", [])
75
+ ], IdempotencyService);
76
+ //# sourceMappingURL=idempotency.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"idempotency.service.js","sourceRoot":"","sources":["../../lib/services/idempotency.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,2CAAqE;AAS9D,IAAM,kBAAkB,0BAAxB,MAAM,kBAAkB;IACZ,MAAM,GAAG,IAAI,eAAM,CAAC,oBAAkB,CAAC,IAAI,CAAC,CAAC;IAEtD,aAAa,GAAG,IAAI,GAAG,EAA4B,CAAC;IACpD,eAAe,GAA0B,IAAI,CAAC;IACrC,UAAU,GAAG,OAAO,CAAC;IAEtC;QACE,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,WAAW,CACT,OAAqB,EACrB,YAAwD;QAExD,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACnD,IAAI,CAAC,GAAG;YAAE,OAAO,KAAK,CAAC;QAEvB,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAED,aAAa,CACX,OAAqB,EACrB,YAAwD;QAExD,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACnD,IAAI,CAAC,GAAG;YAAE,OAAO;QAEjB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,EAAE;YAC1B,GAAG;YACH,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB,CACd,QAAwB,EACxB,YAAwD;QAExD,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC,CAAC;IACxE,CAAC;IAEO,UAAU,CAChB,OAAqB,EACrB,YAAwD;QAExD,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,YAAY,CAAC,OAAO,CAAC,CAAC;QAC/B,CAAC;QAED,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,iBAAiB,CAAC,CAAC;QACpD,IAAI,MAAM,EAAE,CAAC;YACX,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACtE,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC,GAAG,EAAE;YACtC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAEvB,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,EAAE,CAAC;gBACxD,IAAI,GAAG,GAAG,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;oBAC5C,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;gBACjC,CAAC;YACH,CAAC;QACH,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACpC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC9B,CAAC;IACH,CAAC;CACF,CAAA;AA/EY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;;GACA,kBAAkB,CA+E9B"}
@@ -0,0 +1,7 @@
1
+ export * from './kafka-core.service';
2
+ export * from './kafka-client.service';
3
+ export * from './consumer-registry.service';
4
+ export * from './batch-processor.service';
5
+ export * from './idempotency.service';
6
+ export * from './pressure-manager.service';
7
+ export * from './dlq.service';
@@ -0,0 +1,24 @@
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
+ __exportStar(require("./kafka-core.service"), exports);
18
+ __exportStar(require("./kafka-client.service"), exports);
19
+ __exportStar(require("./consumer-registry.service"), exports);
20
+ __exportStar(require("./batch-processor.service"), exports);
21
+ __exportStar(require("./idempotency.service"), exports);
22
+ __exportStar(require("./pressure-manager.service"), exports);
23
+ __exportStar(require("./dlq.service"), exports);
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../lib/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAqC;AACrC,yDAAuC;AACvC,8DAA4C;AAC5C,4DAA0C;AAC1C,wDAAsC;AACtC,6DAA2C;AAC3C,gDAA8B"}
@@ -0,0 +1,31 @@
1
+ import { OnModuleInit, OnApplicationShutdown } from '@nestjs/common';
2
+ import { KafkaModuleOptions, ProducerMessage, SendOptions } from '../interfaces';
3
+ import { KafkaCoreService } from './kafka-core.service';
4
+ export declare class KafkaClient implements OnModuleInit, OnApplicationShutdown {
5
+ private readonly options;
6
+ private readonly kafkaCore;
7
+ private readonly logger;
8
+ private producer;
9
+ private isConnected;
10
+ private batchBuffer;
11
+ private batchTimer;
12
+ private readonly defaultBatchSize;
13
+ private readonly defaultBatchTimeout;
14
+ constructor(options: KafkaModuleOptions, kafkaCore: KafkaCoreService);
15
+ onModuleInit(): Promise<void>;
16
+ onApplicationShutdown(): Promise<void>;
17
+ connect(): Promise<void>;
18
+ disconnect(): Promise<void>;
19
+ send(topic: string, message: ProducerMessage, options?: SendOptions): Promise<void>;
20
+ sendBatch(topic: string, messages: ProducerMessage[], options?: SendOptions): Promise<void>;
21
+ sendMultiTopicBatch(topicMessages: Array<{
22
+ topic: string;
23
+ messages: ProducerMessage[];
24
+ }>, options?: SendOptions): Promise<void>;
25
+ sendQueued(topic: string, message: ProducerMessage): Promise<void>;
26
+ private serializeMessage;
27
+ private scheduleBatchFlush;
28
+ private flushBatch;
29
+ private flushAllBatches;
30
+ isHealthy(): boolean;
31
+ }