From d6dde34ad30d57a8af2768146cc3fb1e2c8dab11 Mon Sep 17 00:00:00 2001 From: Federico Fissore Date: Thu, 30 Sep 2021 18:03:34 +0200 Subject: [PATCH] Use `str(Schema)` rather than `Schema.to_json` to prevent fastavro from raising exception `TypeError: unhashable type: 'mappingproxy'` Fixes #1156 --- src/confluent_kafka/avro/serializer/message_serializer.py | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/confluent_kafka/avro/serializer/message_serializer.py b/src/confluent_kafka/avro/serializer/message_serializer.py index 9023cb63d..1eeb04bf3 100644 --- a/src/confluent_kafka/avro/serializer/message_serializer.py +++ b/src/confluent_kafka/avro/serializer/message_serializer.py @@ -20,6 +20,7 @@ # derived from https://github.com/verisign/python-confluent-schemaregistry.git # import io +import json import logging import struct import sys @@ -79,7 +80,7 @@ def __init__(self, registry_client, reader_key_schema=None, reader_value_schema= # Encoder support def _get_encoder_func(self, writer_schema): if HAS_FAST: - schema = writer_schema.to_json() + schema = json.loads(str(writer_schema)) parsed_schema = parse_schema(schema) return lambda record, fp: schemaless_writer(fp, parsed_schema, record) writer = avro.io.DatumWriter(writer_schema) @@ -175,8 +176,8 @@ def _get_decoder_func(self, schema_id, payload, is_key=False): if HAS_FAST: # try to use fast avro try: - fast_avro_writer_schema = parse_schema(writer_schema_obj.to_json()) - fast_avro_reader_schema = parse_schema(reader_schema_obj.to_json()) + fast_avro_writer_schema = parse_schema(json.loads(str(writer_schema_obj))) + fast_avro_reader_schema = parse_schema(json.loads(str(reader_schema_obj))) schemaless_reader(payload, fast_avro_writer_schema) # If we reach this point, this means we have fastavro and it can