summaryrefslogtreecommitdiff
path: root/kafka/protocol/metadata.py
diff options
context:
space:
mode:
authorDana Powers <dana.powers@gmail.com>2018-02-05 17:35:44 -0800
committerDana Powers <dana.powers@gmail.com>2018-02-05 17:35:44 -0800
commitaa838e15ff33b4f3546c0f68d9ddb8638fd637ee (patch)
treef63ee51d9362cd42d756378b442018bf461de742 /kafka/protocol/metadata.py
parent441aeb864519d2f574650e24a327423308adca03 (diff)
downloadkafka-python-protocol_1_0_0.tar.gz
Add Request/Response structs for kafka broker 1.0.0protocol_1_0_0
Diffstat (limited to 'kafka/protocol/metadata.py')
-rw-r--r--kafka/protocol/metadata.py43
1 files changed, 41 insertions, 2 deletions
diff --git a/kafka/protocol/metadata.py b/kafka/protocol/metadata.py
index 2be8209..2aafdd3 100644
--- a/kafka/protocol/metadata.py
+++ b/kafka/protocol/metadata.py
@@ -102,6 +102,32 @@ class MetadataResponse_v4(Response):
SCHEMA = MetadataResponse_v3.SCHEMA
+class MetadataResponse_v5(Response):
+ API_KEY = 3
+ API_VERSION = 5
+ SCHEMA = Schema(
+ ('throttle_time_ms', Int32),
+ ('brokers', Array(
+ ('node_id', Int32),
+ ('host', String('utf-8')),
+ ('port', Int32),
+ ('rack', String('utf-8')))),
+ ('cluster_id', String('utf-8')),
+ ('controller_id', Int32),
+ ('topics', Array(
+ ('error_code', Int16),
+ ('topic', String('utf-8')),
+ ('is_internal', Boolean),
+ ('partitions', Array(
+ ('error_code', Int16),
+ ('partition', Int32),
+ ('leader', Int32),
+ ('replicas', Array(Int32)),
+ ('isr', Array(Int32)),
+ ('offline_replicas', Array(Int32))))))
+ )
+
+
class MetadataRequest_v0(Request):
API_KEY = 3
API_VERSION = 0
@@ -151,11 +177,24 @@ class MetadataRequest_v4(Request):
NO_TOPICS = None # Empty array (len 0) for topics returns no topics
+class MetadataRequest_v5(Request):
+ """
+ The v5 metadata request is the same as v4.
+ An additional field for offline_replicas has been added to the v5 metadata response
+ """
+ API_KEY = 3
+ API_VERSION = 5
+ RESPONSE_TYPE = MetadataResponse_v5
+ SCHEMA = MetadataRequest_v4.SCHEMA
+ ALL_TOPICS = -1 # Null Array (len -1) for topics returns all topics
+ NO_TOPICS = None # Empty array (len 0) for topics returns no topics
+
+
MetadataRequest = [
MetadataRequest_v0, MetadataRequest_v1, MetadataRequest_v2,
- MetadataRequest_v3, MetadataRequest_v4
+ MetadataRequest_v3, MetadataRequest_v4, MetadataRequest_v5
]
MetadataResponse = [
MetadataResponse_v0, MetadataResponse_v1, MetadataResponse_v2,
- MetadataResponse_v3, MetadataResponse_v4
+ MetadataResponse_v3, MetadataResponse_v4, MetadataResponse_v5
]