diff options
author | Dana Powers <dana.powers@gmail.com> | 2018-02-05 17:35:44 -0800 |
---|---|---|
committer | Dana Powers <dana.powers@gmail.com> | 2018-02-05 17:35:44 -0800 |
commit | aa838e15ff33b4f3546c0f68d9ddb8638fd637ee (patch) | |
tree | f63ee51d9362cd42d756378b442018bf461de742 /kafka/protocol/metadata.py | |
parent | 441aeb864519d2f574650e24a327423308adca03 (diff) | |
download | kafka-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.py | 43 |
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 ] |