diff options
| author | Dana Powers <dana.powers@rd.io> | 2015-11-28 19:41:06 +0800 | 
|---|---|---|
| committer | Zack Dever <zack.dever@rd.io> | 2015-12-04 11:25:39 -0800 | 
| commit | a85e09df89a43de5b659a0fa4ed35bec37c60e04 (patch) | |
| tree | a539af32fe502006c1f35b96d8ae36225292f7a5 /kafka/protocol/offset.py | |
| parent | e24a4d5f5252d6f97ac586e328b95779ef83f4b6 (diff) | |
| download | kafka-python-a85e09df89a43de5b659a0fa4ed35bec37c60e04.tar.gz | |
Rework protocol type definition: AbstractType, Schema, Struct
Diffstat (limited to 'kafka/protocol/offset.py')
| -rw-r--r-- | kafka/protocol/offset.py | 32 | 
1 files changed, 32 insertions, 0 deletions
| diff --git a/kafka/protocol/offset.py b/kafka/protocol/offset.py new file mode 100644 index 0000000..942bdbf --- /dev/null +++ b/kafka/protocol/offset.py @@ -0,0 +1,32 @@ +from .struct import Struct +from .types import Array, Int16, Int32, Int64, Schema, String + + +class OffsetRequest(Struct): +    API_KEY = 2 +    API_VERSION = 0 +    SCHEMA = Schema( +        ('replica_id', Int32), +        ('topics', Array( +            ('topic', String('utf-8')), +            ('partitions', Array( +                ('partition', Int32), +                ('time', Int64), +                ('max_offsets', Int32))))) +    ) +    DEFAULTS = { +        'replica_id': -1 +    } + + +class OffsetResponse(Struct): +    API_KEY = 2 +    API_VERSION = 0 +    SCHEMA = Schema( +        ('topics', Array( +            ('topic', String('utf-8')), +            ('partitions', Array( +                ('partition', Int32), +                ('error_code', Int16), +                ('offsets', Array(Int64)))))) +    ) | 
