org.apache.pekko.serialization.SerializationSetup.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pekko-actor_2.13 Show documentation
Show all versions of pekko-actor_2.13 Show documentation
Apache Pekko is a toolkit for building highly concurrent, distributed, and resilient message-driven applications for Java and Scala.
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* license agreements; and to You under the Apache License, version 2.0:
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* This file is part of the Apache Pekko project, which was derived from Akka.
*/
/*
* Copyright (C) 2016-2022 Lightbend Inc.
*/
package org.apache.pekko.serialization
import scala.collection.immutable
import org.apache.pekko
import pekko.actor.ExtendedActorSystem
import pekko.actor.setup.Setup
import pekko.util.ccompat.JavaConverters._
object SerializationSetup {
/**
* Scala API: Programmatic definition of serializers
* @param createSerializers create pairs of serializer and the set of classes it should be used for
*/
def apply(createSerializers: ExtendedActorSystem => immutable.Seq[SerializerDetails]): SerializationSetup = {
new SerializationSetup(createSerializers)
}
/**
* Java API: Programmatic definition of serializers
* @param createSerializers create pairs of serializer and the set of classes it should be used for
*/
def create(createSerializers: pekko.japi.Function[ExtendedActorSystem, java.util.List[SerializerDetails]])
: SerializationSetup =
apply(sys => createSerializers(sys).asScala.toVector)
}
/**
* Setup for the serialization subsystem, constructor is *Internal API*, use factories in [[SerializationSetup]]
*/
final class SerializationSetup private (val createSerializers: ExtendedActorSystem => immutable.Seq[SerializerDetails])
extends Setup
object SerializerDetails {
/**
* Scala API: factory for details about one programmatically setup serializer
*
* @param alias Register the serializer under this alias (this allows it to be used by bindings in the config)
* @param useFor A set of classes or superclasses to bind to the serializer, selection works just as if
* the classes, the alias and the serializer had been in the config.
*/
def apply(alias: String, serializer: Serializer, useFor: immutable.Seq[Class[_]]): SerializerDetails =
new SerializerDetails(alias, serializer, useFor)
/**
* Java API: factory for details about one programmatically setup serializer
*
* @param alias Register the serializer under this alias (this allows it to be used by bindings in the config)
* @param useFor A set of classes or superclasses to bind to the serializer, selection works just as if
* the classes, the alias and the serializer had been in the config.
*/
def create(alias: String, serializer: Serializer, useFor: java.util.List[Class[_]]): SerializerDetails =
apply(alias, serializer, useFor.asScala.toVector)
}
/**
* Constructor is internal API: Use the factories [[SerializerDetails#create]] or [[SerializerDetails#apply]]
* to construct
*/
final class SerializerDetails private (
val alias: String,
val serializer: Serializer,
val useFor: immutable.Seq[Class[_]])
© 2015 - 2025 Weber Informatics LLC | Privacy Policy