class PolymorphicSerializer<T : Any> : AbstractPolymorphicSerializer<T>
This class provides support for multiplatform polymorphic serialization for interfaces and abstract classes.
To avoid the most common security pitfalls and reflective lookup (and potential load) of an arbitrary class, all serializable implementations of any polymorphic type must be registered in advance in the scope of base polymorphic type, efficiently preventing unbounded polymorphic serialization of an arbitrary type.
Polymorphic serialization is enabled automatically by default for interfaces and Serializable abstract classes.
To enable this feature explicitly on other types, use @SerializableWith(PolymorphicSerializer::class)
or Polymorphic annotation on the property.
Usage of the polymorphic serialization can be demonstrated by the following example:
abstract class BaseRequest()
@Serializable
data class RequestA(val id: Int): BaseRequest()
@Serializable
data class RequestB(val s: String): BaseRequest()
abstract class BaseResponse()
@Serializable
data class ResponseC(val payload: Long): BaseResponse()
@Serializable
data class ResponseD(val payload: ByteArray): BaseResponse()
@Serializable
data class Message(
@Polymorphic val request: BaseRequest,
@Polymorphic val response: BaseResponse
)
In this example, both request and response in Message
are serializable with PolymorphicSerializer.
BaseRequest
and BaseResponse
are base classes and they are captured during compile time by the plugin.
Yet PolymorphicSerializer for BaseRequest
should only allow RequestA
and RequestB
serializers, and none of the response's serializers.
This is achieved via special registration function in the module:
val requestAndResponseModule = SerializersModule {
polymorphic(BaseRequest::class) {
subclass<RequestA>()
subclass<RequestB>()
}
polymorphic(BaseResponse::class) {
subclass<ResponseC>()
subclass<ResponseD>()
}
}
See Also
SerializersModuleBuilder.polymorphic
(common, js, jvm, native)
<init> |
This class provides support for multiplatform polymorphic serialization for interfaces and abstract classes. <init>(baseClass: KClass<T>) |
(common, js, jvm, native)
baseClass |
Base class for all classes that this polymorphic serializer can serialize or deserialize. val baseClass: KClass<T> |
(common, js, jvm, native)
descriptor |
Describes the structure of the serializable representation of T, produced by this serializer. Knowing the structure of the descriptor is required to determine the shape of the serialized form (e.g. what elements are encoded as lists and what as primitives) along with its metadata such as alternative names. val descriptor: SerialDescriptor |