Skip to content

Commit

Permalink
feat: adding support to receive kafka message headers on topic subscr…
Browse files Browse the repository at this point in the history
…iber method
  • Loading branch information
matcampos committed Oct 18, 2021
1 parent 97dcdac commit e639616
Show file tree
Hide file tree
Showing 4 changed files with 38 additions and 26 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@ export class Consumer {
}

@SubscribeTo('hero.kill.dragon')
async getWorld(data: any, key: any, offset: number, timestamp: number): Promise<void> {
async getWorld(data: any, key: any, offset: number, timestamp: number, partition: number, headers: IHeaders): Promise<void> {
...
}

Expand Down
45 changes: 26 additions & 19 deletions src/deserializer/kafka-response.deserializer.ts
Original file line number Diff line number Diff line change
@@ -1,27 +1,34 @@
import { Deserializer } from "@nestjs/microservices";
import { KafkaResponse } from "../interfaces";
import { Deserializer } from '@nestjs/microservices';
import { KafkaResponse } from '../interfaces';

export class KafkaResponseDeserializer
implements Deserializer<any, KafkaResponse> {
implements Deserializer<any, KafkaResponse>
{
deserialize(message: any, options?: Record<string, any>): KafkaResponse {
const { key, value, timestamp, offset, headers } = message;
let id = key;
let response = value;

deserialize(message: any, options?: Record<string, any>): KafkaResponse {
const { key, value, timestamp, offset } = message;
let id = key;
let response = value;
if (Buffer.isBuffer(key)) {
id = Buffer.from(key).toString();
}

if (Buffer.isBuffer(key)) {
id = Buffer.from(key).toString()
}
if (Buffer.isBuffer(value)) {
response = Buffer.from(value).toString();
}

if (Buffer.isBuffer(value)) {
response = Buffer.from(value).toString()
Object.keys(headers).forEach((key) => {
if (Buffer.isBuffer(headers[key])) {
headers[key] = Buffer.from(headers[key]).toString();
}
});

return {
key: id,
response,
timestamp,
offset
};
}
return {
key: id,
response,
timestamp,
offset,
headers,
};
}
}
13 changes: 9 additions & 4 deletions src/interfaces.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,15 @@ import {
} from 'kafkajs';
import { ModuleMetadata, Type } from '@nestjs/common';

export interface IHeaders {
[key: string]: any;
}
export interface KafkaResponse<T = any> {
response: T;
key: string;
timestamp: string;
offset: number;
headers?: IHeaders;
}
export interface KafkaModuleOption {
name: string;
Expand All @@ -28,7 +32,7 @@ export interface KafkaModuleOption {
serializer?: Serializer;
consumeFromBeginning?: boolean;
seek?: Record<string, number | 'earliest' | Date>;
autoConnect?: boolean
autoConnect?: boolean;
};
}
export interface KafkaMessageObject extends Message {
Expand All @@ -51,6 +55,7 @@ export interface KafkaModuleOptionsAsync
export interface KafkaOptionsFactory {
creatKafkaModuleOptions(): Promise<KafkaModuleOption[]> | KafkaModuleOption[];
}
export interface KafkaTransaction extends Omit<Transaction, 'send' | 'sendBatch'> {
send(message: KafkaMessageSend): Promise<RecordMetadata[]>
}
export interface KafkaTransaction
extends Omit<Transaction, 'send' | 'sendBatch'> {
send(message: KafkaMessageSend): Promise<RecordMetadata[]>;
}
4 changes: 2 additions & 2 deletions src/kafka.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -245,8 +245,8 @@ export class KafkaService implements OnModuleInit, OnModuleDestroy {
const callback = SUBSCRIBER_MAP.get(topic);

try {
const { timestamp, response, offset, key } = await this.deserializer.deserialize(message, { topic });
await callback.apply(objectRef, [response, key, offset, timestamp, partition]);
const { timestamp, response, offset, key, headers } = await this.deserializer.deserialize(message, { topic });
await callback.apply(objectRef, [response, key, offset, timestamp, partition, headers]);
} catch(e) {
this.logger.error(`Error for message ${topic}: ${e}`);

Expand Down

0 comments on commit e639616

Please sign in to comment.