All Downloads are FREE. Search and download functionalities are using the official Maven repository.

kalix.spring.boot.KalixConfiguration.scala Maven / Gradle / Ivy

There is a newer version: 1.4.1
Show newest version
/*
 * Copyright 2021 Lightbend Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package kalix.spring.boot

import com.typesafe.config.Config
import com.typesafe.config.ConfigFactory
import kalix.javasdk.client.ComponentClient
import kalix.spring.impl.KalixSpringApplication
import org.springframework.beans.factory.config.BeanPostProcessor
import org.springframework.boot.autoconfigure.AutoConfiguration
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingClass
import org.springframework.boot.autoconfigure.web.reactive.ReactiveWebServerFactoryAutoConfiguration
import org.springframework.context.ApplicationContext
import org.springframework.context.annotation.Bean
import org.springframework.stereotype.Component

object KalixConfiguration {
  def beanPostProcessorErrorMessage(beanClass: Class[_]): String =
    s"${beanClass.getName} is a Kalix component and is marked as a Spring bean for automatic wiring. " +
    "Kalix components cannot be accessed directly and therefore cannot be wired into other classes. " +
    "In order to interact with a Kalix component, you should call it using the provided KalixClient."
}

@AutoConfiguration(
  // ReactiveWebServerFactoryAutoConfiguration is responsible for auto-configure the ReactiveWebServer
  // it has different pre-defined configs, ie: Tomcat, Netty, Jetty. And it will load one of them if its server is in
  // the classpath. It turns out that we need reactor-netty dependency for the WebClient, but we don't want Spring Boot
  // to configure it as the main ReactiveWebServer. Therefore, we must require our AutoConfigure to be loaded
  // before NettyReactiveWebServer is loaded
  before = Array(classOf[ReactiveWebServerFactoryAutoConfiguration]))
@ConditionalOnMissingClass(Array("kalix.spring.boot.KalixConfigurationTest"))
class KalixConfiguration(applicationContext: ApplicationContext) {

  @Bean
  def config(): Config = ConfigFactory.load()

  @Bean
  def kalixSpringApplication(config: Config): KalixSpringApplication =
    new KalixSpringApplication(applicationContext, config)

  @Bean
  def componentClient(kalixSpringApplication: KalixSpringApplication): ComponentClient =
    kalixSpringApplication.componentClient

  @Bean
  def kalixReactiveWebServerFactory(kalixSpringApplication: KalixSpringApplication) =
    new KalixReactiveWebServerFactory(kalixSpringApplication)

  @Component
  class KalixComponentInjectionBlocker extends BeanPostProcessor {
    override def postProcessBeforeInitialization(bean: AnyRef, beanName: String): AnyRef = {
      if (KalixSpringApplication.kalixComponents.exists(_.isAssignableFrom(bean.getClass)))
        throw new IllegalArgumentException(KalixConfiguration.beanPostProcessorErrorMessage(bean.getClass))
      bean
    }
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy