-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* replace most scala.reflect usages with java.nio corresponding classes * bump embeddedKafka version to 2.4.1 add AvroSerdes and deprecate package methods, improve test classes
- Loading branch information
Francesco Pellegrini
committed
Mar 18, 2020
1 parent
9e47a32
commit e33d1b6
Showing
12 changed files
with
186 additions
and
174 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
58 changes: 58 additions & 0 deletions
58
src/main/scala/net.manub.embeddedkafka/schemaregistry/avro/AvroSerdes.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
package net.manub.embeddedkafka.schemaregistry.avro | ||
|
||
import io.confluent.kafka.serializers.{ | ||
KafkaAvroDeserializer => ConfluentKafkaAvroDeserializer, | ||
KafkaAvroSerializer => ConfluentKafkaAvroSerializer | ||
} | ||
import net.manub.embeddedkafka.schemaregistry.EmbeddedKafka.{ | ||
configForSchemaRegistry, | ||
specificAvroReaderConfigForSchemaRegistry | ||
} | ||
import net.manub.embeddedkafka.schemaregistry.EmbeddedKafkaConfig | ||
import org.apache.avro.generic.GenericRecord | ||
import org.apache.avro.specific.SpecificRecord | ||
import org.apache.kafka.common.serialization.{Serde, Serdes} | ||
|
||
import scala.collection.JavaConverters._ | ||
|
||
object AvroSerdes { | ||
|
||
def specific[T <: SpecificRecord]( | ||
isKey: Boolean = false, | ||
extraConfig: Map[String, Object] = Map.empty | ||
)( | ||
implicit config: EmbeddedKafkaConfig | ||
): Serde[T] = { | ||
serdeFrom[T]( | ||
configForSchemaRegistry ++ extraConfig, | ||
specificAvroReaderConfigForSchemaRegistry ++ extraConfig, //need this to support SpecificRecord | ||
isKey | ||
) | ||
} | ||
|
||
def generic( | ||
isKey: Boolean = false, | ||
extraConfig: Map[String, Object] = Map.empty | ||
)( | ||
implicit config: EmbeddedKafkaConfig | ||
): Serde[GenericRecord] = { | ||
serdeFrom[GenericRecord]( | ||
configForSchemaRegistry ++ extraConfig, | ||
configForSchemaRegistry ++ extraConfig, | ||
isKey | ||
) | ||
} | ||
|
||
private def serdeFrom[T]( | ||
serConfig: Map[String, Object], | ||
deserConfig: Map[String, Object], | ||
isKey: Boolean | ||
): Serde[T] = { | ||
val ser = new ConfluentKafkaAvroSerializer | ||
ser.configure(serConfig.asJava, isKey) | ||
val deser = new ConfluentKafkaAvroDeserializer | ||
deser.configure(deserConfig.asJava, isKey) | ||
|
||
Serdes.serdeFrom(ser, deser).asInstanceOf[Serde[T]] | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
89 changes: 26 additions & 63 deletions
89
src/main/scala/net.manub.embeddedkafka/schemaregistry/package.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,84 +1,47 @@ | ||
package net.manub.embeddedkafka | ||
|
||
import io.confluent.kafka.serializers.{ | ||
KafkaAvroDeserializer => ConfluentKafkaAvroDeserializer, | ||
KafkaAvroSerializer => ConfluentKafkaAvroSerializer | ||
} | ||
import net.manub.embeddedkafka.schemaregistry.EmbeddedKafka.{ | ||
configForSchemaRegistry, | ||
specificAvroReaderConfigForSchemaRegistry | ||
} | ||
import net.manub.embeddedkafka.schemaregistry.{ | ||
EmbeddedKafkaConfig => EmbeddedKafkaSRConfig | ||
} | ||
import net.manub.embeddedkafka.schemaregistry.avro.AvroSerdes | ||
import org.apache.avro.generic.GenericRecord | ||
import org.apache.avro.specific.SpecificRecord | ||
import org.apache.kafka.common.serialization.{ | ||
Deserializer, | ||
Serde, | ||
Serdes, | ||
Serializer | ||
} | ||
|
||
import scala.collection.JavaConverters._ | ||
import org.apache.kafka.common.serialization.{Deserializer, Serde, Serializer} | ||
|
||
package object schemaregistry { | ||
// SpecificRecord | ||
@deprecated("Use AvroSerdes.specific instead", since = "2.4.1") | ||
implicit def specificAvroValueSerde[T <: SpecificRecord]( | ||
implicit config: EmbeddedKafkaSRConfig | ||
): Serde[T] = { | ||
serdeFrom[T]( | ||
configForSchemaRegistry, | ||
specificAvroReaderConfigForSchemaRegistry, //need this to support SpecificRecord | ||
isKey = false | ||
) | ||
} | ||
implicit config: EmbeddedKafkaConfig | ||
): Serde[T] = | ||
AvroSerdes.specific[T]() | ||
|
||
@deprecated("Use AvroSerdes.specific instead", since = "2.4.1") | ||
implicit def specificAvroValueSerializer[T <: SpecificRecord]( | ||
implicit config: EmbeddedKafkaSRConfig | ||
): Serializer[T] = { | ||
specificAvroValueSerde[T].serializer | ||
} | ||
implicit config: EmbeddedKafkaConfig | ||
): Serializer[T] = | ||
AvroSerdes.specific[T]().serializer | ||
|
||
@deprecated("Use AvroSerdes.specific instead", since = "2.4.1") | ||
implicit def specificAvroValueDeserializer[T <: SpecificRecord]( | ||
implicit config: EmbeddedKafkaSRConfig | ||
): Deserializer[T] = { | ||
specificAvroValueSerde[T].deserializer | ||
} | ||
implicit config: EmbeddedKafkaConfig | ||
): Deserializer[T] = | ||
AvroSerdes.specific[T]().deserializer | ||
|
||
// GenericRecord | ||
@deprecated("Use AvroSerdes.generic instead", since = "2.4.1") | ||
implicit def genericAvroValueSerde( | ||
implicit config: EmbeddedKafkaSRConfig | ||
): Serde[GenericRecord] = { | ||
serdeFrom[GenericRecord]( | ||
configForSchemaRegistry, | ||
configForSchemaRegistry, | ||
isKey = false | ||
) | ||
} | ||
implicit config: EmbeddedKafkaConfig | ||
): Serde[GenericRecord] = | ||
AvroSerdes.generic() | ||
|
||
@deprecated("Use AvroSerdes.generic instead", since = "2.4.1") | ||
implicit def genericAvroValueSerializer( | ||
implicit config: EmbeddedKafkaSRConfig | ||
): Serializer[GenericRecord] = { | ||
genericAvroValueSerde.serializer | ||
} | ||
implicit config: EmbeddedKafkaConfig | ||
): Serializer[GenericRecord] = | ||
AvroSerdes.generic().serializer | ||
|
||
@deprecated("Use AvroSerdes.generic instead", since = "2.4.1") | ||
implicit def genericAvroValueDeserializer( | ||
implicit config: EmbeddedKafkaSRConfig | ||
): Deserializer[GenericRecord] = { | ||
genericAvroValueSerde.deserializer | ||
} | ||
|
||
private def serdeFrom[T]( | ||
serConfig: Map[String, Object], | ||
deserConfig: Map[String, Object], | ||
isKey: Boolean | ||
) = { | ||
val ser = new ConfluentKafkaAvroSerializer | ||
ser.configure(serConfig.asJava, isKey) | ||
val deser = new ConfluentKafkaAvroDeserializer | ||
deser.configure(deserConfig.asJava, isKey) | ||
implicit config: EmbeddedKafkaConfig | ||
): Deserializer[GenericRecord] = | ||
AvroSerdes.generic().deserializer | ||
|
||
Serdes.serdeFrom(ser, deser).asInstanceOf[Serde[T]] | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
15 changes: 0 additions & 15 deletions
15
...n/scala/net.manub.embeddedkafka/schemaregistry/streams/EmbeddedKafkaStreamsAllInOne.scala
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.