package sarama //ApiVersionsResponseBlock is an api version reponse block type type ApiVersionsResponseBlock struct { ApiKey int16 MinVersion int16 MaxVersion int16 } func (b *ApiVersionsResponseBlock) encode(pe packetEncoder) error { pe.putInt16(b.ApiKey) pe.putInt16(b.MinVersion) pe.putInt16(b.MaxVersion) return nil } func (b *ApiVersionsResponseBlock) decode(pd packetDecoder) error { var err error if b.ApiKey, err = pd.getInt16(); err != nil { return err } if b.MinVersion, err = pd.getInt16(); err != nil { return err } if b.MaxVersion, err = pd.getInt16(); err != nil { return err } return nil } //ApiVersionsResponse is an api version response type type ApiVersionsResponse struct { Err KError ApiVersions []*ApiVersionsResponseBlock } func (r *ApiVersionsResponse) encode(pe packetEncoder) error { pe.putInt16(int16(r.Err)) if err := pe.putArrayLength(len(r.ApiVersions)); err != nil { return err } for _, apiVersion := range r.ApiVersions { if err := apiVersion.encode(pe); err != nil { return err } } return nil } func (r *ApiVersionsResponse) decode(pd packetDecoder, version int16) error { kerr, err := pd.getInt16() if err != nil { return err } r.Err = KError(kerr) numBlocks, err := pd.getArrayLength() if err != nil { return err } r.ApiVersions = make([]*ApiVersionsResponseBlock, numBlocks) for i := 0; i < numBlocks; i++ { block := new(ApiVersionsResponseBlock) if err := block.decode(pd); err != nil { return err } r.ApiVersions[i] = block } return nil } func (r *ApiVersionsResponse) key() int16 { return 18 } func (r *ApiVersionsResponse) version() int16 { return 0 } func (r *ApiVersionsResponse) requiredVersion() KafkaVersion { return V0_10_0_0 }