UNPKG

kafkajs

Version:

A modern Apache Kafka client for node.js

59 lines (50 loc) 1.52 kB
const Decoder = require('../../../decoder') const { failure, createErrorFromCode } = require('../../../error') /** * DescribeGroups Response (Version: 0) => [groups] * groups => error_code group_id state protocol_type protocol [members] * error_code => INT16 * group_id => STRING * state => STRING * protocol_type => STRING * protocol => STRING * members => member_id client_id client_host member_metadata member_assignment * member_id => STRING * client_id => STRING * client_host => STRING * member_metadata => BYTES * member_assignment => BYTES */ const decoderMember = decoder => ({ memberId: decoder.readString(), clientId: decoder.readString(), clientHost: decoder.readString(), memberMetadata: decoder.readBytes(), memberAssignment: decoder.readBytes(), }) const decodeGroup = decoder => ({ errorCode: decoder.readInt16(), groupId: decoder.readString(), state: decoder.readString(), protocolType: decoder.readString(), protocol: decoder.readString(), members: decoder.readArray(decoderMember), }) const decode = async rawData => { const decoder = new Decoder(rawData) const groups = decoder.readArray(decodeGroup) return { groups, } } const parse = async data => { const groupsWithError = data.groups.filter(({ errorCode }) => failure(errorCode)) if (groupsWithError.length > 0) { throw createErrorFromCode(groupsWithError[0].errorCode) } return data } module.exports = { decode, parse, }