kafkajs
Version:
A modern Apache Kafka client for node.js
32 lines (28 loc) • 965 B
JavaScript
const Encoder = require('../../../encoder')
const { JoinGroup: apiKey } = require('../../apiKeys')
/**
* JoinGroup Request (Version: 0) => group_id session_timeout member_id protocol_type [group_protocols]
* group_id => STRING
* session_timeout => INT32
* member_id => STRING
* protocol_type => STRING
* group_protocols => protocol_name protocol_metadata
* protocol_name => STRING
* protocol_metadata => BYTES
*/
module.exports = ({ groupId, sessionTimeout, memberId, protocolType, groupProtocols }) => ({
apiKey,
apiVersion: 0,
apiName: 'JoinGroup',
encode: async () => {
return new Encoder()
.writeString(groupId)
.writeInt32(sessionTimeout)
.writeString(memberId)
.writeString(protocolType)
.writeArray(groupProtocols.map(encodeGroupProtocols))
},
})
const encodeGroupProtocols = ({ name, metadata = Buffer.alloc(0) }) => {
return new Encoder().writeString(name).writeBytes(metadata)
}