- Add schema reconstruction functions to convert SMQ RecordValue back to Kafka format
- Implement Confluent envelope reconstruction with proper schema metadata
- Add Kafka record batch creation for schematized messages
- Include topic-based schema detection and metadata retrieval
- Add comprehensive round-trip testing for Avro schema reconstruction
- Fix envelope parsing to avoid Protobuf interference with Avro messages
- Prepare foundation for full SeaweedMQ integration in Phase 8
This enables the Kafka Gateway to reconstruct original message formats on Fetch.
- Add ProtobufDecoder with dynamic message handling via protoreflect
- Support Protobuf binary data decoding to Go maps and SMQ RecordValue
- Implement Confluent Protobuf envelope parsing with varint indexes
- Add Protobuf-to-RecordType inference with nested message support
- Include Protobuf encoding for round-trip message reconstruction
- Integrate Protobuf support into Schema Manager with caching
- Add varint encoding/decoding utilities for Protobuf indexes
- Prepare foundation for full FileDescriptorSet parsing in Phase 8
This enables the Kafka Gateway to process Protobuf-schematized messages.
- Add Schema Manager to coordinate registry, decoders, and validation
- Integrate schema management into Handler with enable/disable controls
- Add schema processing functions in Produce path for schematized messages
- Support both permissive and strict validation modes
- Include message extraction and compatibility validation stubs
- Add comprehensive Manager tests with mock registry server
- Prepare foundation for SeaweedMQ integration in Phase 8
This enables the Kafka Gateway to detect, decode, and process schematized messages.
- Add goavro dependency for Avro schema parsing and decoding
- Implement AvroDecoder with binary data decoding to Go maps
- Add MapToRecordValue() to convert Go values to schema_pb.RecordValue
- Support complex types: records, arrays, unions, primitives
- Add type inference from decoded maps to generate RecordType schemas
- Handle Avro union types and null values correctly
- Comprehensive test coverage including integration tests
This enables conversion of Avro messages to SeaweedMQ format.
- Implement RegistryClient with full REST API support
- Add LRU caching for schemas and subjects with configurable TTL
- Support schema registration, compatibility checking, and listing
- Include automatic format detection (Avro/Protobuf/JSON Schema)
- Add health check and cache management functionality
- Comprehensive test coverage with mock HTTP server
This provides the foundation for schema resolution and validation.
- Implement ParseConfluentEnvelope() to detect and extract schema info
- Add support for magic byte (0x00) + schema ID extraction
- Include envelope validation and metadata extraction
- Add comprehensive unit tests with 100% coverage
- Prepare foundation for Avro/Protobuf/JSON Schema support
This enables detection of schematized Kafka messages for gateway processing.