diff options
author | Dana Powers <dana.powers@gmail.com> | 2017-07-09 08:04:39 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-07-09 08:04:39 -0700 |
commit | d0c6b1f95c2e677545d1faaeae525e8768abea9e (patch) | |
tree | 4c889cb6be669e36e4992a74ece3b8e7038d0c80 /kafka/protocol/metadata.py | |
parent | 2f75169504c8bd6f31ab4a88823a8073eb57eced (diff) | |
download | kafka-python-d0c6b1f95c2e677545d1faaeae525e8768abea9e.tar.gz |
Protocol updates for 0.11.0.0 (#1127)
Diffstat (limited to 'kafka/protocol/metadata.py')
-rw-r--r-- | kafka/protocol/metadata.py | 63 |
1 files changed, 61 insertions, 2 deletions
diff --git a/kafka/protocol/metadata.py b/kafka/protocol/metadata.py index 907ec25..2be8209 100644 --- a/kafka/protocol/metadata.py +++ b/kafka/protocol/metadata.py @@ -71,6 +71,37 @@ class MetadataResponse_v2(Response): ) +class MetadataResponse_v3(Response): + API_KEY = 3 + API_VERSION = 3 + 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)))))) + ) + + +class MetadataResponse_v4(Response): + API_KEY = 3 + API_VERSION = 4 + SCHEMA = MetadataResponse_v3.SCHEMA + + class MetadataRequest_v0(Request): API_KEY = 3 API_VERSION = 0 @@ -95,8 +126,36 @@ class MetadataRequest_v2(Request): API_VERSION = 2 RESPONSE_TYPE = MetadataResponse_v2 SCHEMA = MetadataRequest_v1.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 + + +class MetadataRequest_v3(Request): + API_KEY = 3 + API_VERSION = 3 + RESPONSE_TYPE = MetadataResponse_v3 + SCHEMA = MetadataRequest_v1.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 + + +class MetadataRequest_v4(Request): + API_KEY = 3 + API_VERSION = 4 + RESPONSE_TYPE = MetadataResponse_v4 + SCHEMA = Schema( + ('topics', Array(String('utf-8'))), + ('allow_auto_topic_creation', Boolean) + ) + 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 = [ + MetadataRequest_v0, MetadataRequest_v1, MetadataRequest_v2, + MetadataRequest_v3, MetadataRequest_v4 +] MetadataResponse = [ - MetadataResponse_v0, MetadataResponse_v1, MetadataResponse_v2] + MetadataResponse_v0, MetadataResponse_v1, MetadataResponse_v2, + MetadataResponse_v3, MetadataResponse_v4 +] |