kafkajs
Version:
A modern Apache Kafka client for node.js
37 lines (32 loc) • 1.03 kB
JavaScript
const { parse, decode: decodeV1 } = require('../v1/response')
/**
* Starting in version 2, on quota violation, brokers send out responses before throttling.
* @see https://cwiki.apache.org/confluence/display/KAFKA/KIP-219+-+Improve+quota+communication
*
* DescribeGroups Response (Version: 2) => throttle_time_ms [groups]
* throttle_time_ms => INT32
* 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 decode = async rawData => {
const decoded = await decodeV1(rawData)
return {
...decoded,
throttleTime: 0,
clientSideThrottleTime: decoded.throttleTime,
}
}
module.exports = {
decode,
parse,
}